<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>{name} - API文档</title>
</head>
<script type="text/javascript">
    /*! jQuery v3.2.1 | (c) JS Foundation and other contributors | jquery.org/license */
    !function (a, b) {
        "use strict";
        "object" == typeof module && "object" == typeof module.exports ? module.exports = a.document ? b(a, !0) : function (a) {
            if (!a.document) throw new Error("jQuery requires a window with a document");
            return b(a)
        } : b(a)
    }("undefined" != typeof window ? window : this, function (a, b) {
        "use strict";
        var c = [], d = a.document, e = Object.getPrototypeOf, f = c.slice, g = c.concat, h = c.push, i = c.indexOf,
          j = {}, k = j.toString, l = j.hasOwnProperty, m = l.toString, n = m.call(Object), o = {};

        function p(a, b) {
            b = b || d;
            var c = b.createElement("script");
            c.text = a, b.head.appendChild(c).parentNode.removeChild(c)
        }

        var q = "3.2.1", r = function (a, b) {
            return new r.fn.init(a, b)
        }, s = /^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, t = /^-ms-/, u = /-([a-z])/g, v = function (a, b) {
            return b.toUpperCase()
        };
        r.fn = r.prototype = {
            jquery: q, constructor: r, length: 0, toArray: function () {
                return f.call(this)
            }, get: function (a) {
                return null == a ? f.call(this) : a < 0 ? this[a + this.length] : this[a]
            }, pushStack: function (a) {
                var b = r.merge(this.constructor(), a);
                return b.prevObject = this, b
            }, each: function (a) {
                return r.each(this, a)
            }, map: function (a) {
                return this.pushStack(r.map(this, function (b, c) {
                    return a.call(b, c, b)
                }))
            }, slice: function () {
                return this.pushStack(f.apply(this, arguments))
            }, first: function () {
                return this.eq(0)
            }, last: function () {
                return this.eq(-1)
            }, eq: function (a) {
                var b = this.length, c = +a + (a < 0 ? b : 0);
                return this.pushStack(c >= 0 && c < b ? [this[c]] : [])
            }, end: function () {
                return this.prevObject || this.constructor()
            }, push: h, sort: c.sort, splice: c.splice
        }, r.extend = r.fn.extend = function () {
            var a, b, c, d, e, f, g = arguments[0] || {}, h = 1, i = arguments.length, j = !1;
            for ("boolean" == typeof g && (j = g, g = arguments[h] || {}, h++), "object" == typeof g || r.isFunction(g) || (g = {}), h === i && (g = this, h--); h < i; h++) if (null != (a = arguments[h])) for (b in a) c = g[b], d = a[b], g !== d && (j && d && (r.isPlainObject(d) || (e = Array.isArray(d))) ? (e ? (e = !1, f = c && Array.isArray(c) ? c : []) : f = c && r.isPlainObject(c) ? c : {}, g[b] = r.extend(j, f, d)) : void 0 !== d && (g[b] = d));
            return g
        }, r.extend({
            expando: "jQuery" + (q + Math.random()).replace(/\D/g, ""), isReady: !0, error: function (a) {
                throw new Error(a)
            }, noop: function () {
            }, isFunction: function (a) {
                return "function" === r.type(a)
            }, isWindow: function (a) {
                return null != a && a === a.window
            }, isNumeric: function (a) {
                var b = r.type(a);
                return ("number" === b || "string" === b) && !isNaN(a - parseFloat(a))
            }, isPlainObject: function (a) {
                var b, c;
                return !(!a || "[object Object]" !== k.call(a)) && (!(b = e(a)) || (c = l.call(b, "constructor") && b.constructor, "function" == typeof c && m.call(c) === n))
            }, isEmptyObject: function (a) {
                var b;
                for (b in a) return !1;
                return !0
            }, type: function (a) {
                return null == a ? a + "" : "object" == typeof a || "function" == typeof a ? j[k.call(a)] || "object" : typeof a
            }, globalEval: function (a) {
                p(a)
            }, camelCase: function (a) {
                return a.replace(t, "ms-").replace(u, v)
            }, each: function (a, b) {
                var c, d = 0;
                if (w(a)) {
                    for (c = a.length; d < c; d++) if (b.call(a[d], d, a[d]) === !1) break
                } else for (d in a) if (b.call(a[d], d, a[d]) === !1) break;
                return a
            }, trim: function (a) {
                return null == a ? "" : (a + "").replace(s, "")
            }, makeArray: function (a, b) {
                var c = b || [];
                return null != a && (w(Object(a)) ? r.merge(c, "string" == typeof a ? [a] : a) : h.call(c, a)), c
            }, inArray: function (a, b, c) {
                return null == b ? -1 : i.call(b, a, c)
            }, merge: function (a, b) {
                for (var c = +b.length, d = 0, e = a.length; d < c; d++) a[e++] = b[d];
                return a.length = e, a
            }, grep: function (a, b, c) {
                for (var d, e = [], f = 0, g = a.length, h = !c; f < g; f++) d = !b(a[f], f), d !== h && e.push(a[f]);
                return e
            }, map: function (a, b, c) {
                var d, e, f = 0, h = [];
                if (w(a)) for (d = a.length; f < d; f++) e = b(a[f], f, c), null != e && h.push(e); else for (f in a) e = b(a[f], f, c), null != e && h.push(e);
                return g.apply([], h)
            }, guid: 1, proxy: function (a, b) {
                var c, d, e;
                if ("string" == typeof b && (c = a[b], b = a, a = c), r.isFunction(a)) return d = f.call(arguments, 2), e = function () {
                    return a.apply(b || this, d.concat(f.call(arguments)))
                }, e.guid = a.guid = a.guid || r.guid++, e
            }, now: Date.now, support: o
        }), "function" == typeof Symbol && (r.fn[Symbol.iterator] = c[Symbol.iterator]), r.each("Boolean Number String Function Array Date RegExp Object Error Symbol".split(" "), function (a, b) {
            j["[object " + b + "]"] = b.toLowerCase()
        });

        function w(a) {
            var b = !!a && "length" in a && a.length, c = r.type(a);
            return "function" !== c && !r.isWindow(a) && ("array" === c || 0 === b || "number" == typeof b && b > 0 && b - 1 in a)
        }

        var x = function (a) {
            var b, c, d, e, f, g, h, i, j, k, l, m, n, o, p, q, r, s, t, u = "sizzle" + 1 * new Date, v = a.document,
              w = 0, x = 0, y = ha(), z = ha(), A = ha(), B = function (a, b) {
                  return a === b && (l = !0), 0
              }, C = {}.hasOwnProperty, D = [], E = D.pop, F = D.push, G = D.push, H = D.slice, I = function (a, b) {
                  for (var c = 0, d = a.length; c < d; c++) if (a[c] === b) return c;
                  return -1
              },
              J = "checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",
              K = "[\\x20\\t\\r\\n\\f]", L = "(?:\\\\.|[\\w-]|[^\0-\\xa0])+",
              M = "\\[" + K + "*(" + L + ")(?:" + K + "*([*^$|!~]?=)" + K + "*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|(" + L + "))|)" + K + "*\\]",
              N = ":(" + L + ")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|" + M + ")*)|.*)\\)|)",
              O = new RegExp(K + "+", "g"), P = new RegExp("^" + K + "+|((?:^|[^\\\\])(?:\\\\.)*)" + K + "+$", "g"),
              Q = new RegExp("^" + K + "*," + K + "*"), R = new RegExp("^" + K + "*([>+~]|" + K + ")" + K + "*"),
              S = new RegExp("=" + K + "*([^\\]'\"]*?)" + K + "*\\]", "g"), T = new RegExp(N),
              U = new RegExp("^" + L + "$"), V = {
                  ID: new RegExp("^#(" + L + ")"), CLASS: new RegExp("^\\.(" + L + ")"),
                  TAG: new RegExp("^(" + L + "|[*])"), ATTR: new RegExp("^" + M), PSEUDO: new RegExp("^" + N),
                  CHILD: new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + K + "*(even|odd|(([+-]|)(\\d*)n|)" + K + "*(?:([+-]|)" + K + "*(\\d+)|))" + K + "*\\)|)", "i"),
                  bool: new RegExp("^(?:" + J + ")$", "i"),
                  needsContext: new RegExp("^" + K + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + K + "*((?:-\\d)?\\d*)" + K + "*\\)|)(?=[^-]|$)", "i")
              }, W = /^(?:input|select|textarea|button)$/i, X = /^h\d$/i, Y = /^[^{]+\{\s*\[native \w/,
              Z = /^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/, $ = /[+~]/,
              _ = new RegExp("\\\\([\\da-f]{1,6}" + K + "?|(" + K + ")|.)", "ig"), aa = function (a, b, c) {
                  var d = "0x" + b - 65536;
                  return d !== d || c ? b : d < 0 ? String.fromCharCode(d + 65536) : String.fromCharCode(d >> 10 | 55296, 1023 & d | 56320)
              }, ba = /([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g, ca = function (a, b) {
                  return b ? "\0" === a ? "\ufffd" : a.slice(0, -1) + "\\" + a.charCodeAt(a.length - 1).toString(16) + " " : "\\" + a
              }, da = function () {
                  m()
              }, ea = ta(function (a) {
                  return a.disabled === !0 && ("form" in a || "label" in a)
              }, {dir: "parentNode", next: "legend"});
            try {
                G.apply(D = H.call(v.childNodes), v.childNodes), D[v.childNodes.length].nodeType
            } catch (fa) {
                G = {
                    apply: D.length ? function (a, b) {
                        F.apply(a, H.call(b))
                    } : function (a, b) {
                        var c = a.length, d = 0;
                        while (a[c++] = b[d++]) ;
                        a.length = c - 1
                    }
                }
            }

            function ga(a, b, d, e) {
                var f, h, j, k, l, o, r, s = b && b.ownerDocument, w = b ? b.nodeType : 9;
                if (d = d || [], "string" != typeof a || !a || 1 !== w && 9 !== w && 11 !== w) return d;
                if (!e && ((b ? b.ownerDocument || b : v) !== n && m(b), b = b || n, p)) {
                    if (11 !== w && (l = Z.exec(a))) if (f = l[1]) {
                        if (9 === w) {
                            if (!(j = b.getElementById(f))) return d;
                            if (j.id === f) return d.push(j), d
                        } else if (s && (j = s.getElementById(f)) && t(b, j) && j.id === f) return d.push(j), d
                    } else {
                        if (l[2]) return G.apply(d, b.getElementsByTagName(a)), d;
                        if ((f = l[3]) && c.getElementsByClassName && b.getElementsByClassName) return G.apply(d, b.getElementsByClassName(f)), d
                    }
                    if (c.qsa && !A[a + " "] && (!q || !q.test(a))) {
                        if (1 !== w) s = b, r = a; else if ("object" !== b.nodeName.toLowerCase()) {
                            (k = b.getAttribute("id")) ? k = k.replace(ba, ca) : b.setAttribute("id", k = u), o = g(a), h = o.length;
                            while (h--) o[h] = "#" + k + " " + sa(o[h]);
                            r = o.join(","), s = $.test(a) && qa(b.parentNode) || b
                        }
                        if (r) try {
                            return G.apply(d, s.querySelectorAll(r)), d
                        } catch (x) {
                        } finally {
                            k === u && b.removeAttribute("id")
                        }
                    }
                }
                return i(a.replace(P, "$1"), b, d, e)
            }

            function ha() {
                var a = [];

                function b(c, e) {
                    return a.push(c + " ") > d.cacheLength && delete b[a.shift()], b[c + " "] = e
                }

                return b
            }

            function ia(a) {
                return a[u] = !0, a
            }

            function ja(a) {
                var b = n.createElement("fieldset");
                try {
                    return !!a(b)
                } catch (c) {
                    return !1
                } finally {
                    b.parentNode && b.parentNode.removeChild(b), b = null
                }
            }

            function ka(a, b) {
                var c = a.split("|"), e = c.length;
                while (e--) d.attrHandle[c[e]] = b
            }

            function la(a, b) {
                var c = b && a, d = c && 1 === a.nodeType && 1 === b.nodeType && a.sourceIndex - b.sourceIndex;
                if (d) return d;
                if (c) while (c = c.nextSibling) if (c === b) return -1;
                return a ? 1 : -1
            }

            function ma(a) {
                return function (b) {
                    var c = b.nodeName.toLowerCase();
                    return "input" === c && b.type === a
                }
            }

            function na(a) {
                return function (b) {
                    var c = b.nodeName.toLowerCase();
                    return ("input" === c || "button" === c) && b.type === a
                }
            }

            function oa(a) {
                return function (b) {
                    return "form" in b ? b.parentNode && b.disabled === !1 ? "label" in b ? "label" in b.parentNode ? b.parentNode.disabled === a : b.disabled === a : b.isDisabled === a || b.isDisabled !== !a && ea(b) === a : b.disabled === a : "label" in b && b.disabled === a
                }
            }

            function pa(a) {
                return ia(function (b) {
                    return b = +b, ia(function (c, d) {
                        var e, f = a([], c.length, b), g = f.length;
                        while (g--) c[e = f[g]] && (c[e] = !(d[e] = c[e]))
                    })
                })
            }

            function qa(a) {
                return a && "undefined" != typeof a.getElementsByTagName && a
            }

            c = ga.support = {}, f = ga.isXML = function (a) {
                var b = a && (a.ownerDocument || a).documentElement;
                return !!b && "HTML" !== b.nodeName
            }, m = ga.setDocument = function (a) {
                var b, e, g = a ? a.ownerDocument || a : v;
                return g !== n && 9 === g.nodeType && g.documentElement ? (n = g, o = n.documentElement, p = !f(n), v !== n && (e = n.defaultView) && e.top !== e && (e.addEventListener ? e.addEventListener("unload", da, !1) : e.attachEvent && e.attachEvent("onunload", da)), c.attributes = ja(function (a) {
                    return a.className = "i", !a.getAttribute("className")
                }), c.getElementsByTagName = ja(function (a) {
                    return a.appendChild(n.createComment("")), !a.getElementsByTagName("*").length
                }), c.getElementsByClassName = Y.test(n.getElementsByClassName), c.getById = ja(function (a) {
                    return o.appendChild(a).id = u, !n.getElementsByName || !n.getElementsByName(u).length
                }), c.getById ? (d.filter.ID = function (a) {
                    var b = a.replace(_, aa);
                    return function (a) {
                        return a.getAttribute("id") === b
                    }
                }, d.find.ID = function (a, b) {
                    if ("undefined" != typeof b.getElementById && p) {
                        var c = b.getElementById(a);
                        return c ? [c] : []
                    }
                }) : (d.filter.ID = function (a) {
                    var b = a.replace(_, aa);
                    return function (a) {
                        var c = "undefined" != typeof a.getAttributeNode && a.getAttributeNode("id");
                        return c && c.value === b
                    }
                }, d.find.ID = function (a, b) {
                    if ("undefined" != typeof b.getElementById && p) {
                        var c, d, e, f = b.getElementById(a);
                        if (f) {
                            if (c = f.getAttributeNode("id"), c && c.value === a) return [f];
                            e = b.getElementsByName(a), d = 0;
                            while (f = e[d++]) if (c = f.getAttributeNode("id"), c && c.value === a) return [f]
                        }
                        return []
                    }
                }), d.find.TAG = c.getElementsByTagName ? function (a, b) {
                    return "undefined" != typeof b.getElementsByTagName ? b.getElementsByTagName(a) : c.qsa ? b.querySelectorAll(a) : void 0
                } : function (a, b) {
                    var c, d = [], e = 0, f = b.getElementsByTagName(a);
                    if ("*" === a) {
                        while (c = f[e++]) 1 === c.nodeType && d.push(c);
                        return d
                    }
                    return f
                }, d.find.CLASS = c.getElementsByClassName && function (a, b) {
                    if ("undefined" != typeof b.getElementsByClassName && p) return b.getElementsByClassName(a)
                }, r = [], q = [], (c.qsa = Y.test(n.querySelectorAll)) && (ja(function (a) {
                    o.appendChild(a).innerHTML = "<a id='" + u + "'></a><select id='" + u + "-\r\\' msallowcapture=''><option selected=''></option></select>", a.querySelectorAll("[msallowcapture^='']").length && q.push("[*^$]=" + K + "*(?:''|\"\")"), a.querySelectorAll("[selected]").length || q.push("\\[" + K + "*(?:value|" + J + ")"), a.querySelectorAll("[id~=" + u + "-]").length || q.push("~="), a.querySelectorAll(":checked").length || q.push(":checked"), a.querySelectorAll("a#" + u + "+*").length || q.push(".#.+[+~]")
                }), ja(function (a) {
                    a.innerHTML = "<a href='' disabled='disabled'></a><select disabled='disabled'><option/></select>";
                    var b = n.createElement("input");
                    b.setAttribute("type", "hidden"), a.appendChild(b).setAttribute("name", "D"), a.querySelectorAll("[name=d]").length && q.push("name" + K + "*[*^$|!~]?="), 2 !== a.querySelectorAll(":enabled").length && q.push(":enabled", ":disabled"), o.appendChild(a).disabled = !0, 2 !== a.querySelectorAll(":disabled").length && q.push(":enabled", ":disabled"), a.querySelectorAll("*,:x"), q.push(",.*:")
                })), (c.matchesSelector = Y.test(s = o.matches || o.webkitMatchesSelector || o.mozMatchesSelector || o.oMatchesSelector || o.msMatchesSelector)) && ja(function (a) {
                    c.disconnectedMatch = s.call(a, "*"), s.call(a, "[s!='']:x"), r.push("!=", N)
                }), q = q.length && new RegExp(q.join("|")), r = r.length && new RegExp(r.join("|")), b = Y.test(o.compareDocumentPosition), t = b || Y.test(o.contains) ? function (a, b) {
                    var c = 9 === a.nodeType ? a.documentElement : a, d = b && b.parentNode;
                    return a === d || !(!d || 1 !== d.nodeType || !(c.contains ? c.contains(d) : a.compareDocumentPosition && 16 & a.compareDocumentPosition(d)))
                } : function (a, b) {
                    if (b) while (b = b.parentNode) if (b === a) return !0;
                    return !1
                }, B = b ? function (a, b) {
                    if (a === b) return l = !0, 0;
                    var d = !a.compareDocumentPosition - !b.compareDocumentPosition;
                    return d ? d : (d = (a.ownerDocument || a) === (b.ownerDocument || b) ? a.compareDocumentPosition(b) : 1, 1 & d || !c.sortDetached && b.compareDocumentPosition(a) === d ? a === n || a.ownerDocument === v && t(v, a) ? -1 : b === n || b.ownerDocument === v && t(v, b) ? 1 : k ? I(k, a) - I(k, b) : 0 : 4 & d ? -1 : 1)
                } : function (a, b) {
                    if (a === b) return l = !0, 0;
                    var c, d = 0, e = a.parentNode, f = b.parentNode, g = [a], h = [b];
                    if (!e || !f) return a === n ? -1 : b === n ? 1 : e ? -1 : f ? 1 : k ? I(k, a) - I(k, b) : 0;
                    if (e === f) return la(a, b);
                    c = a;
                    while (c = c.parentNode) g.unshift(c);
                    c = b;
                    while (c = c.parentNode) h.unshift(c);
                    while (g[d] === h[d]) d++;
                    return d ? la(g[d], h[d]) : g[d] === v ? -1 : h[d] === v ? 1 : 0
                }, n) : n
            }, ga.matches = function (a, b) {
                return ga(a, null, null, b)
            }, ga.matchesSelector = function (a, b) {
                if ((a.ownerDocument || a) !== n && m(a), b = b.replace(S, "='$1']"), c.matchesSelector && p && !A[b + " "] && (!r || !r.test(b)) && (!q || !q.test(b))) try {
                    var d = s.call(a, b);
                    if (d || c.disconnectedMatch || a.document && 11 !== a.document.nodeType) return d
                } catch (e) {
                }
                return ga(b, n, null, [a]).length > 0
            }, ga.contains = function (a, b) {
                return (a.ownerDocument || a) !== n && m(a), t(a, b)
            }, ga.attr = function (a, b) {
                (a.ownerDocument || a) !== n && m(a);
                var e = d.attrHandle[b.toLowerCase()],
                  f = e && C.call(d.attrHandle, b.toLowerCase()) ? e(a, b, !p) : void 0;
                return void 0 !== f ? f : c.attributes || !p ? a.getAttribute(b) : (f = a.getAttributeNode(b)) && f.specified ? f.value : null
            }, ga.escape = function (a) {
                return (a + "").replace(ba, ca)
            }, ga.error = function (a) {
                throw new Error("Syntax error, unrecognized expression: " + a)
            }, ga.uniqueSort = function (a) {
                var b, d = [], e = 0, f = 0;
                if (l = !c.detectDuplicates, k = !c.sortStable && a.slice(0), a.sort(B), l) {
                    while (b = a[f++]) b === a[f] && (e = d.push(f));
                    while (e--) a.splice(d[e], 1)
                }
                return k = null, a
            }, e = ga.getText = function (a) {
                var b, c = "", d = 0, f = a.nodeType;
                if (f) {
                    if (1 === f || 9 === f || 11 === f) {
                        if ("string" == typeof a.textContent) return a.textContent;
                        for (a = a.firstChild; a; a = a.nextSibling) c += e(a)
                    } else if (3 === f || 4 === f) return a.nodeValue
                } else while (b = a[d++]) c += e(b);
                return c
            }, d = ga.selectors = {
                cacheLength: 50, createPseudo: ia, match: V, attrHandle: {}, find: {}, relative: {
                    ">": {dir: "parentNode", first: !0}, " ": {dir: "parentNode"},
                    "+": {dir: "previousSibling", first: !0}, "~": {dir: "previousSibling"}
                }, preFilter: {
                    ATTR: function (a) {
                        return a[1] = a[1].replace(_, aa), a[3] = (a[3] || a[4] || a[5] || "").replace(_, aa), "~=" === a[2] && (a[3] = " " + a[3] + " "), a.slice(0, 4)
                    }, CHILD: function (a) {
                        return a[1] = a[1].toLowerCase(), "nth" === a[1].slice(0, 3) ? (a[3] || ga.error(a[0]), a[4] = +(a[4] ? a[5] + (a[6] || 1) : 2 * ("even" === a[3] || "odd" === a[3])), a[5] = +(a[7] + a[8] || "odd" === a[3])) : a[3] && ga.error(a[0]), a
                    }, PSEUDO: function (a) {
                        var b, c = !a[6] && a[2];
                        return V.CHILD.test(a[0]) ? null : (a[3] ? a[2] = a[4] || a[5] || "" : c && T.test(c) && (b = g(c, !0)) && (b = c.indexOf(")", c.length - b) - c.length) && (a[0] = a[0].slice(0, b), a[2] = c.slice(0, b)), a.slice(0, 3))
                    }
                }, filter: {
                    TAG: function (a) {
                        var b = a.replace(_, aa).toLowerCase();
                        return "*" === a ? function () {
                            return !0
                        } : function (a) {
                            return a.nodeName && a.nodeName.toLowerCase() === b
                        }
                    }, CLASS: function (a) {
                        var b = y[a + " "];
                        return b || (b = new RegExp("(^|" + K + ")" + a + "(" + K + "|$)")) && y(a, function (a) {
                            return b.test("string" == typeof a.className && a.className || "undefined" != typeof a.getAttribute && a.getAttribute("class") || "")
                        })
                    }, ATTR: function (a, b, c) {
                        return function (d) {
                            var e = ga.attr(d, a);
                            return null == e ? "!=" === b : !b || (e += "", "=" === b ? e === c : "!=" === b ? e !== c : "^=" === b ? c && 0 === e.indexOf(c) : "*=" === b ? c && e.indexOf(c) > -1 : "$=" === b ? c && e.slice(-c.length) === c : "~=" === b ? (" " + e.replace(O, " ") + " ").indexOf(c) > -1 : "|=" === b && (e === c || e.slice(0, c.length + 1) === c + "-"))
                        }
                    }, CHILD: function (a, b, c, d, e) {
                        var f = "nth" !== a.slice(0, 3), g = "last" !== a.slice(-4), h = "of-type" === b;
                        return 1 === d && 0 === e ? function (a) {
                            return !!a.parentNode
                        } : function (b, c, i) {
                            var j, k, l, m, n, o, p = f !== g ? "nextSibling" : "previousSibling", q = b.parentNode,
                              r = h && b.nodeName.toLowerCase(), s = !i && !h, t = !1;
                            if (q) {
                                if (f) {
                                    while (p) {
                                        m = b;
                                        while (m = m[p]) if (h ? m.nodeName.toLowerCase() === r : 1 === m.nodeType) return !1;
                                        o = p = "only" === a && !o && "nextSibling"
                                    }
                                    return !0
                                }
                                if (o = [g ? q.firstChild : q.lastChild], g && s) {
                                    m = q, l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), j = k[a] || [], n = j[0] === w && j[1], t = n && j[2], m = n && q.childNodes[n];
                                    while (m = ++n && m && m[p] || (t = n = 0) || o.pop()) if (1 === m.nodeType && ++t && m === b) {
                                        k[a] = [w, n, t];
                                        break
                                    }
                                } else if (s && (m = b, l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), j = k[a] || [], n = j[0] === w && j[1], t = n), t === !1) while (m = ++n && m && m[p] || (t = n = 0) || o.pop()) if ((h ? m.nodeName.toLowerCase() === r : 1 === m.nodeType) && ++t && (s && (l = m[u] || (m[u] = {}), k = l[m.uniqueID] || (l[m.uniqueID] = {}), k[a] = [w, t]), m === b)) break;
                                return t -= e, t === d || t % d === 0 && t / d >= 0
                            }
                        }
                    }, PSEUDO: function (a, b) {
                        var c,
                          e = d.pseudos[a] || d.setFilters[a.toLowerCase()] || ga.error("unsupported pseudo: " + a);
                        return e[u] ? e(b) : e.length > 1 ? (c = [a, a, "", b], d.setFilters.hasOwnProperty(a.toLowerCase()) ? ia(function (a, c) {
                            var d, f = e(a, b), g = f.length;
                            while (g--) d = I(a, f[g]), a[d] = !(c[d] = f[g])
                        }) : function (a) {
                            return e(a, 0, c)
                        }) : e
                    }
                }, pseudos: {
                    not: ia(function (a) {
                        var b = [], c = [], d = h(a.replace(P, "$1"));
                        return d[u] ? ia(function (a, b, c, e) {
                            var f, g = d(a, null, e, []), h = a.length;
                            while (h--) (f = g[h]) && (a[h] = !(b[h] = f))
                        }) : function (a, e, f) {
                            return b[0] = a, d(b, null, f, c), b[0] = null, !c.pop()
                        }
                    }), has: ia(function (a) {
                        return function (b) {
                            return ga(a, b).length > 0
                        }
                    }), contains: ia(function (a) {
                        return a = a.replace(_, aa), function (b) {
                            return (b.textContent || b.innerText || e(b)).indexOf(a) > -1
                        }
                    }), lang: ia(function (a) {
                        return U.test(a || "") || ga.error("unsupported lang: " + a), a = a.replace(_, aa).toLowerCase(), function (b) {
                            var c;
                            do if (c = p ? b.lang : b.getAttribute("xml:lang") || b.getAttribute("lang")) return c = c.toLowerCase(), c === a || 0 === c.indexOf(a + "-"); while ((b = b.parentNode) && 1 === b.nodeType);
                            return !1
                        }
                    }), target: function (b) {
                        var c = a.location && a.location.hash;
                        return c && c.slice(1) === b.id
                    }, root: function (a) {
                        return a === o
                    }, focus: function (a) {
                        return a === n.activeElement && (!n.hasFocus || n.hasFocus()) && !!(a.type || a.href || ~a.tabIndex)
                    }, enabled: oa(!1), disabled: oa(!0), checked: function (a) {
                        var b = a.nodeName.toLowerCase();
                        return "input" === b && !!a.checked || "option" === b && !!a.selected
                    }, selected: function (a) {
                        return a.parentNode && a.parentNode.selectedIndex, a.selected === !0
                    }, empty: function (a) {
                        for (a = a.firstChild; a; a = a.nextSibling) if (a.nodeType < 6) return !1;
                        return !0
                    }, parent: function (a) {
                        return !d.pseudos.empty(a)
                    }, header: function (a) {
                        return X.test(a.nodeName)
                    }, input: function (a) {
                        return W.test(a.nodeName)
                    }, button: function (a) {
                        var b = a.nodeName.toLowerCase();
                        return "input" === b && "button" === a.type || "button" === b
                    }, text: function (a) {
                        var b;
                        return "input" === a.nodeName.toLowerCase() && "text" === a.type && (null == (b = a.getAttribute("type")) || "text" === b.toLowerCase())
                    }, first: pa(function () {
                        return [0]
                    }), last: pa(function (a, b) {
                        return [b - 1]
                    }), eq: pa(function (a, b, c) {
                        return [c < 0 ? c + b : c]
                    }), even: pa(function (a, b) {
                        for (var c = 0; c < b; c += 2) a.push(c);
                        return a
                    }), odd: pa(function (a, b) {
                        for (var c = 1; c < b; c += 2) a.push(c);
                        return a
                    }), lt: pa(function (a, b, c) {
                        for (var d = c < 0 ? c + b : c; --d >= 0;) a.push(d);
                        return a
                    }), gt: pa(function (a, b, c) {
                        for (var d = c < 0 ? c + b : c; ++d < b;) a.push(d);
                        return a
                    })
                }
            }, d.pseudos.nth = d.pseudos.eq;
            for (b in {radio: !0, checkbox: !0, file: !0, password: !0, image: !0}) d.pseudos[b] = ma(b);
            for (b in {submit: !0, reset: !0}) d.pseudos[b] = na(b);

            function ra() {
            }

            ra.prototype = d.filters = d.pseudos, d.setFilters = new ra, g = ga.tokenize = function (a, b) {
                var c, e, f, g, h, i, j, k = z[a + " "];
                if (k) return b ? 0 : k.slice(0);
                h = a, i = [], j = d.preFilter;
                while (h) {
                    c && !(e = Q.exec(h)) || (e && (h = h.slice(e[0].length) || h), i.push(f = [])), c = !1, (e = R.exec(h)) && (c = e.shift(), f.push({
                        value: c, type: e[0].replace(P, " ")
                    }), h = h.slice(c.length));
                    for (g in d.filter) !(e = V[g].exec(h)) || j[g] && !(e = j[g](e)) || (c = e.shift(), f.push({
                        value: c, type: g, matches: e
                    }), h = h.slice(c.length));
                    if (!c) break
                }
                return b ? h.length : h ? ga.error(a) : z(a, i).slice(0)
            };

            function sa(a) {
                for (var b = 0, c = a.length, d = ""; b < c; b++) d += a[b].value;
                return d
            }

            function ta(a, b, c) {
                var d = b.dir, e = b.next, f = e || d, g = c && "parentNode" === f, h = x++;
                return b.first ? function (b, c, e) {
                    while (b = b[d]) if (1 === b.nodeType || g) return a(b, c, e);
                    return !1
                } : function (b, c, i) {
                    var j, k, l, m = [w, h];
                    if (i) {
                        while (b = b[d]) if ((1 === b.nodeType || g) && a(b, c, i)) return !0
                    } else while (b = b[d]) if (1 === b.nodeType || g) if (l = b[u] || (b[u] = {}), k = l[b.uniqueID] || (l[b.uniqueID] = {}), e && e === b.nodeName.toLowerCase()) b = b[d] || b; else {
                        if ((j = k[f]) && j[0] === w && j[1] === h) return m[2] = j[2];
                        if (k[f] = m, m[2] = a(b, c, i)) return !0
                    }
                    return !1
                }
            }

            function ua(a) {
                return a.length > 1 ? function (b, c, d) {
                    var e = a.length;
                    while (e--) if (!a[e](b, c, d)) return !1;
                    return !0
                } : a[0]
            }

            function va(a, b, c) {
                for (var d = 0, e = b.length; d < e; d++) ga(a, b[d], c);
                return c
            }

            function wa(a, b, c, d, e) {
                for (var f, g = [], h = 0, i = a.length, j = null != b; h < i; h++) (f = a[h]) && (c && !c(f, d, e) || (g.push(f), j && b.push(h)));
                return g
            }

            function xa(a, b, c, d, e, f) {
                return d && !d[u] && (d = xa(d)), e && !e[u] && (e = xa(e, f)), ia(function (f, g, h, i) {
                    var j, k, l, m = [], n = [], o = g.length, p = f || va(b || "*", h.nodeType ? [h] : h, []),
                      q = !a || !f && b ? p : wa(p, m, a, h, i), r = c ? e || (f ? a : o || d) ? [] : g : q;
                    if (c && c(q, r, h, i), d) {
                        j = wa(r, n), d(j, [], h, i), k = j.length;
                        while (k--) (l = j[k]) && (r[n[k]] = !(q[n[k]] = l))
                    }
                    if (f) {
                        if (e || a) {
                            if (e) {
                                j = [], k = r.length;
                                while (k--) (l = r[k]) && j.push(q[k] = l);
                                e(null, r = [], j, i)
                            }
                            k = r.length;
                            while (k--) (l = r[k]) && (j = e ? I(f, l) : m[k]) > -1 && (f[j] = !(g[j] = l))
                        }
                    } else r = wa(r === g ? r.splice(o, r.length) : r), e ? e(null, g, r, i) : G.apply(g, r)
                })
            }

            function ya(a) {
                for (var b, c, e, f = a.length, g = d.relative[a[0].type], h = g || d.relative[" "], i = g ? 1 : 0, k = ta(function (a) {
                    return a === b
                }, h, !0), l = ta(function (a) {
                    return I(b, a) > -1
                }, h, !0), m = [function (a, c, d) {
                    var e = !g && (d || c !== j) || ((b = c).nodeType ? k(a, c, d) : l(a, c, d));
                    return b = null, e
                }]; i < f; i++) if (c = d.relative[a[i].type]) m = [ta(ua(m), c)]; else {
                    if (c = d.filter[a[i].type].apply(null, a[i].matches), c[u]) {
                        for (e = ++i; e < f; e++) if (d.relative[a[e].type]) break;
                        return xa(i > 1 && ua(m), i > 1 && sa(a.slice(0, i - 1).concat({value: " " === a[i - 2].type ? "*" : ""})).replace(P, "$1"), c, i < e && ya(a.slice(i, e)), e < f && ya(a = a.slice(e)), e < f && sa(a))
                    }
                    m.push(c)
                }
                return ua(m)
            }

            function za(a, b) {
                var c = b.length > 0, e = a.length > 0, f = function (f, g, h, i, k) {
                    var l, o, q, r = 0, s = "0", t = f && [], u = [], v = j, x = f || e && d.find.TAG("*", k),
                      y = w += null == v ? 1 : Math.random() || .1, z = x.length;
                    for (k && (j = g === n || g || k); s !== z && null != (l = x[s]); s++) {
                        if (e && l) {
                            o = 0, g || l.ownerDocument === n || (m(l), h = !p);
                            while (q = a[o++]) if (q(l, g || n, h)) {
                                i.push(l);
                                break
                            }
                            k && (w = y)
                        }
                        c && ((l = !q && l) && r--, f && t.push(l))
                    }
                    if (r += s, c && s !== r) {
                        o = 0;
                        while (q = b[o++]) q(t, u, g, h);
                        if (f) {
                            if (r > 0) while (s--) t[s] || u[s] || (u[s] = E.call(i));
                            u = wa(u)
                        }
                        G.apply(i, u), k && !f && u.length > 0 && r + b.length > 1 && ga.uniqueSort(i)
                    }
                    return k && (w = y, j = v), t
                };
                return c ? ia(f) : f
            }

            return h = ga.compile = function (a, b) {
                var c, d = [], e = [], f = A[a + " "];
                if (!f) {
                    b || (b = g(a)), c = b.length;
                    while (c--) f = ya(b[c]), f[u] ? d.push(f) : e.push(f);
                    f = A(a, za(e, d)), f.selector = a
                }
                return f
            }, i = ga.select = function (a, b, c, e) {
                var f, i, j, k, l, m = "function" == typeof a && a, n = !e && g(a = m.selector || a);
                if (c = c || [], 1 === n.length) {
                    if (i = n[0] = n[0].slice(0), i.length > 2 && "ID" === (j = i[0]).type && 9 === b.nodeType && p && d.relative[i[1].type]) {
                        if (b = (d.find.ID(j.matches[0].replace(_, aa), b) || [])[0], !b) return c;
                        m && (b = b.parentNode), a = a.slice(i.shift().value.length)
                    }
                    f = V.needsContext.test(a) ? 0 : i.length;
                    while (f--) {
                        if (j = i[f], d.relative[k = j.type]) break;
                        if ((l = d.find[k]) && (e = l(j.matches[0].replace(_, aa), $.test(i[0].type) && qa(b.parentNode) || b))) {
                            if (i.splice(f, 1), a = e.length && sa(i), !a) return G.apply(c, e), c;
                            break
                        }
                    }
                }
                return (m || h(a, n))(e, b, !p, c, !b || $.test(a) && qa(b.parentNode) || b), c
            }, c.sortStable = u.split("").sort(B).join("") === u, c.detectDuplicates = !!l, m(), c.sortDetached = ja(function (a) {
                return 1 & a.compareDocumentPosition(n.createElement("fieldset"))
            }), ja(function (a) {
                return a.innerHTML = "<a href='#'></a>", "#" === a.firstChild.getAttribute("href")
            }) || ka("type|href|height|width", function (a, b, c) {
                if (!c) return a.getAttribute(b, "type" === b.toLowerCase() ? 1 : 2)
            }), c.attributes && ja(function (a) {
                return a.innerHTML = "<input/>", a.firstChild.setAttribute("value", ""), "" === a.firstChild.getAttribute("value")
            }) || ka("value", function (a, b, c) {
                if (!c && "input" === a.nodeName.toLowerCase()) return a.defaultValue
            }), ja(function (a) {
                return null == a.getAttribute("disabled")
            }) || ka(J, function (a, b, c) {
                var d;
                if (!c) return a[b] === !0 ? b.toLowerCase() : (d = a.getAttributeNode(b)) && d.specified ? d.value : null
            }), ga
        }(a);
        r.find = x, r.expr = x.selectors, r.expr[":"] = r.expr.pseudos, r.uniqueSort = r.unique = x.uniqueSort, r.text = x.getText, r.isXMLDoc = x.isXML, r.contains = x.contains, r.escapeSelector = x.escape;
        var y = function (a, b, c) {
            var d = [], e = void 0 !== c;
            while ((a = a[b]) && 9 !== a.nodeType) if (1 === a.nodeType) {
                if (e && r(a).is(c)) break;
                d.push(a)
            }
            return d
        }, z = function (a, b) {
            for (var c = []; a; a = a.nextSibling) 1 === a.nodeType && a !== b && c.push(a);
            return c
        }, A = r.expr.match.needsContext;

        function B(a, b) {
            return a.nodeName && a.nodeName.toLowerCase() === b.toLowerCase()
        }

        var C = /^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i, D = /^.[^:#\[\.,]*$/;

        function E(a, b, c) {
            return r.isFunction(b) ? r.grep(a, function (a, d) {
                return !!b.call(a, d, a) !== c
            }) : b.nodeType ? r.grep(a, function (a) {
                return a === b !== c
            }) : "string" != typeof b ? r.grep(a, function (a) {
                return i.call(b, a) > -1 !== c
            }) : D.test(b) ? r.filter(b, a, c) : (b = r.filter(b, a), r.grep(a, function (a) {
                return i.call(b, a) > -1 !== c && 1 === a.nodeType
            }))
        }

        r.filter = function (a, b, c) {
            var d = b[0];
            return c && (a = ":not(" + a + ")"), 1 === b.length && 1 === d.nodeType ? r.find.matchesSelector(d, a) ? [d] : [] : r.find.matches(a, r.grep(b, function (a) {
                return 1 === a.nodeType
            }))
        }, r.fn.extend({
            find: function (a) {
                var b, c, d = this.length, e = this;
                if ("string" != typeof a) return this.pushStack(r(a).filter(function () {
                    for (b = 0; b < d; b++) if (r.contains(e[b], this)) return !0
                }));
                for (c = this.pushStack([]), b = 0; b < d; b++) r.find(a, e[b], c);
                return d > 1 ? r.uniqueSort(c) : c
            }, filter: function (a) {
                return this.pushStack(E(this, a || [], !1))
            }, not: function (a) {
                return this.pushStack(E(this, a || [], !0))
            }, is: function (a) {
                return !!E(this, "string" == typeof a && A.test(a) ? r(a) : a || [], !1).length
            }
        });
        var F, G = /^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/, H = r.fn.init = function (a, b, c) {
            var e, f;
            if (!a) return this;
            if (c = c || F, "string" == typeof a) {
                if (e = "<" === a[0] && ">" === a[a.length - 1] && a.length >= 3 ? [null, a, null] : G.exec(a), !e || !e[1] && b) return !b || b.jquery ? (b || c).find(a) : this.constructor(b).find(a);
                if (e[1]) {
                    if (b = b instanceof r ? b[0] : b, r.merge(this, r.parseHTML(e[1], b && b.nodeType ? b.ownerDocument || b : d, !0)), C.test(e[1]) && r.isPlainObject(b)) for (e in b) r.isFunction(this[e]) ? this[e](b[e]) : this.attr(e, b[e]);
                    return this
                }
                return f = d.getElementById(e[2]), f && (this[0] = f, this.length = 1), this
            }
            return a.nodeType ? (this[0] = a, this.length = 1, this) : r.isFunction(a) ? void 0 !== c.ready ? c.ready(a) : a(r) : r.makeArray(a, this)
        };
        H.prototype = r.fn, F = r(d);
        var I = /^(?:parents|prev(?:Until|All))/, J = {children: !0, contents: !0, next: !0, prev: !0};
        r.fn.extend({
            has: function (a) {
                var b = r(a, this), c = b.length;
                return this.filter(function () {
                    for (var a = 0; a < c; a++) if (r.contains(this, b[a])) return !0
                })
            }, closest: function (a, b) {
                var c, d = 0, e = this.length, f = [], g = "string" != typeof a && r(a);
                if (!A.test(a)) for (; d < e; d++) for (c = this[d]; c && c !== b; c = c.parentNode) if (c.nodeType < 11 && (g ? g.index(c) > -1 : 1 === c.nodeType && r.find.matchesSelector(c, a))) {
                    f.push(c);
                    break
                }
                return this.pushStack(f.length > 1 ? r.uniqueSort(f) : f)
            }, index: function (a) {
                return a ? "string" == typeof a ? i.call(r(a), this[0]) : i.call(this, a.jquery ? a[0] : a) : this[0] && this[0].parentNode ? this.first().prevAll().length : -1
            }, add: function (a, b) {
                return this.pushStack(r.uniqueSort(r.merge(this.get(), r(a, b))))
            }, addBack: function (a) {
                return this.add(null == a ? this.prevObject : this.prevObject.filter(a))
            }
        });

        function K(a, b) {
            while ((a = a[b]) && 1 !== a.nodeType) ;
            return a
        }

        r.each({
            parent: function (a) {
                var b = a.parentNode;
                return b && 11 !== b.nodeType ? b : null
            }, parents: function (a) {
                return y(a, "parentNode")
            }, parentsUntil: function (a, b, c) {
                return y(a, "parentNode", c)
            }, next: function (a) {
                return K(a, "nextSibling")
            }, prev: function (a) {
                return K(a, "previousSibling")
            }, nextAll: function (a) {
                return y(a, "nextSibling")
            }, prevAll: function (a) {
                return y(a, "previousSibling")
            }, nextUntil: function (a, b, c) {
                return y(a, "nextSibling", c)
            }, prevUntil: function (a, b, c) {
                return y(a, "previousSibling", c)
            }, siblings: function (a) {
                return z((a.parentNode || {}).firstChild, a)
            }, children: function (a) {
                return z(a.firstChild)
            }, contents: function (a) {
                return B(a, "iframe") ? a.contentDocument : (B(a, "template") && (a = a.content || a), r.merge([], a.childNodes))
            }
        }, function (a, b) {
            r.fn[a] = function (c, d) {
                var e = r.map(this, b, c);
                return "Until" !== a.slice(-5) && (d = c), d && "string" == typeof d && (e = r.filter(d, e)), this.length > 1 && (J[a] || r.uniqueSort(e), I.test(a) && e.reverse()), this.pushStack(e)
            }
        });
        var L = /[^\x20\t\r\n\f]+/g;

        function M(a) {
            var b = {};
            return r.each(a.match(L) || [], function (a, c) {
                b[c] = !0
            }), b
        }

        r.Callbacks = function (a) {
            a = "string" == typeof a ? M(a) : r.extend({}, a);
            var b, c, d, e, f = [], g = [], h = -1, i = function () {
                for (e = e || a.once, d = b = !0; g.length; h = -1) {
                    c = g.shift();
                    while (++h < f.length) f[h].apply(c[0], c[1]) === !1 && a.stopOnFalse && (h = f.length, c = !1)
                }
                a.memory || (c = !1), b = !1, e && (f = c ? [] : "")
            }, j = {
                add: function () {
                    return f && (c && !b && (h = f.length - 1, g.push(c)), function d(b) {
                        r.each(b, function (b, c) {
                            r.isFunction(c) ? a.unique && j.has(c) || f.push(c) : c && c.length && "string" !== r.type(c) && d(c)
                        })
                    }(arguments), c && !b && i()), this
                }, remove: function () {
                    return r.each(arguments, function (a, b) {
                        var c;
                        while ((c = r.inArray(b, f, c)) > -1) f.splice(c, 1), c <= h && h--
                    }), this
                }, has: function (a) {
                    return a ? r.inArray(a, f) > -1 : f.length > 0
                }, empty: function () {
                    return f && (f = []), this
                }, disable: function () {
                    return e = g = [], f = c = "", this
                }, disabled: function () {
                    return !f
                }, lock: function () {
                    return e = g = [], c || b || (f = c = ""), this
                }, locked: function () {
                    return !!e
                }, fireWith: function (a, c) {
                    return e || (c = c || [], c = [a, c.slice ? c.slice() : c], g.push(c), b || i()), this
                }, fire: function () {
                    return j.fireWith(this, arguments), this
                }, fired: function () {
                    return !!d
                }
            };
            return j
        };

        function N(a) {
            return a
        }

        function O(a) {
            throw a
        }

        function P(a, b, c, d) {
            var e;
            try {
                a && r.isFunction(e = a.promise) ? e.call(a).done(b).fail(c) : a && r.isFunction(e = a.then) ? e.call(a, b, c) : b.apply(void 0, [a].slice(d))
            } catch (a) {
                c.apply(void 0, [a])
            }
        }

        r.extend({
            Deferred: function (b) {
                var c = [["notify", "progress", r.Callbacks("memory"), r.Callbacks("memory"), 2], ["resolve", "done", r.Callbacks("once memory"), r.Callbacks("once memory"), 0, "resolved"], ["reject", "fail", r.Callbacks("once memory"), r.Callbacks("once memory"), 1, "rejected"]],
                  d = "pending", e = {
                      state: function () {
                          return d
                      }, always: function () {
                          return f.done(arguments).fail(arguments), this
                      }, "catch": function (a) {
                          return e.then(null, a)
                      }, pipe: function () {
                          var a = arguments;
                          return r.Deferred(function (b) {
                              r.each(c, function (c, d) {
                                  var e = r.isFunction(a[d[4]]) && a[d[4]];
                                  f[d[1]](function () {
                                      var a = e && e.apply(this, arguments);
                                      a && r.isFunction(a.promise) ? a.promise().progress(b.notify).done(b.resolve).fail(b.reject) : b[d[0] + "With"](this, e ? [a] : arguments)
                                  })
                              }), a = null
                          }).promise()
                      }, then: function (b, d, e) {
                          var f = 0;

                          function g(b, c, d, e) {
                              return function () {
                                  var h = this, i = arguments, j = function () {
                                      var a, j;
                                      if (!(b < f)) {
                                          if (a = d.apply(h, i), a === c.promise()) throw new TypeError("Thenable self-resolution");
                                          j = a && ("object" == typeof a || "function" == typeof a) && a.then, r.isFunction(j) ? e ? j.call(a, g(f, c, N, e), g(f, c, O, e)) : (f++, j.call(a, g(f, c, N, e), g(f, c, O, e), g(f, c, N, c.notifyWith))) : (d !== N && (h = void 0, i = [a]), (e || c.resolveWith)(h, i))
                                      }
                                  }, k = e ? j : function () {
                                      try {
                                          j()
                                      } catch (a) {
                                          r.Deferred.exceptionHook && r.Deferred.exceptionHook(a, k.stackTrace), b + 1 >= f && (d !== O && (h = void 0, i = [a]), c.rejectWith(h, i))
                                      }
                                  };
                                  b ? k() : (r.Deferred.getStackHook && (k.stackTrace = r.Deferred.getStackHook()), a.setTimeout(k))
                              }
                          }

                          return r.Deferred(function (a) {
                              c[0][3].add(g(0, a, r.isFunction(e) ? e : N, a.notifyWith)), c[1][3].add(g(0, a, r.isFunction(b) ? b : N)), c[2][3].add(g(0, a, r.isFunction(d) ? d : O))
                          }).promise()
                      }, promise: function (a) {
                          return null != a ? r.extend(a, e) : e
                      }
                  }, f = {};
                return r.each(c, function (a, b) {
                    var g = b[2], h = b[5];
                    e[b[1]] = g.add, h && g.add(function () {
                        d = h
                    }, c[3 - a][2].disable, c[0][2].lock), g.add(b[3].fire), f[b[0]] = function () {
                        return f[b[0] + "With"](this === f ? void 0 : this, arguments), this
                    }, f[b[0] + "With"] = g.fireWith
                }), e.promise(f), b && b.call(f, f), f
            }, when: function (a) {
                var b = arguments.length, c = b, d = Array(c), e = f.call(arguments), g = r.Deferred(),
                  h = function (a) {
                      return function (c) {
                          d[a] = this, e[a] = arguments.length > 1 ? f.call(arguments) : c, --b || g.resolveWith(d, e)
                      }
                  };
                if (b <= 1 && (P(a, g.done(h(c)).resolve, g.reject, !b), "pending" === g.state() || r.isFunction(e[c] && e[c].then))) return g.then();
                while (c--) P(e[c], h(c), g.reject);
                return g.promise()
            }
        });
        var Q = /^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;
        r.Deferred.exceptionHook = function (b, c) {
            a.console && a.console.warn && b && Q.test(b.name) && a.console.warn("jQuery.Deferred exception: " + b.message, b.stack, c)
        }, r.readyException = function (b) {
            a.setTimeout(function () {
                throw b
            })
        };
        var R = r.Deferred();
        r.fn.ready = function (a) {
            return R.then(a)["catch"](function (a) {
                r.readyException(a)
            }), this
        }, r.extend({
            isReady: !1, readyWait: 1, ready: function (a) {
                (a === !0 ? --r.readyWait : r.isReady) || (r.isReady = !0, a !== !0 && --r.readyWait > 0 || R.resolveWith(d, [r]))
            }
        }), r.ready.then = R.then;

        function S() {
            d.removeEventListener("DOMContentLoaded", S),
              a.removeEventListener("load", S), r.ready()
        }

        "complete" === d.readyState || "loading" !== d.readyState && !d.documentElement.doScroll ? a.setTimeout(r.ready) : (d.addEventListener("DOMContentLoaded", S), a.addEventListener("load", S));
        var T = function (a, b, c, d, e, f, g) {
            var h = 0, i = a.length, j = null == c;
            if ("object" === r.type(c)) {
                e = !0;
                for (h in c) T(a, b, h, c[h], !0, f, g)
            } else if (void 0 !== d && (e = !0, r.isFunction(d) || (g = !0), j && (g ? (b.call(a, d), b = null) : (j = b, b = function (a, b, c) {
                return j.call(r(a), c)
            })), b)) for (; h < i; h++) b(a[h], c, g ? d : d.call(a[h], h, b(a[h], c)));
            return e ? a : j ? b.call(a) : i ? b(a[0], c) : f
        }, U = function (a) {
            return 1 === a.nodeType || 9 === a.nodeType || !+a.nodeType
        };

        function V() {
            this.expando = r.expando + V.uid++
        }

        V.uid = 1, V.prototype = {
            cache: function (a) {
                var b = a[this.expando];
                return b || (b = {}, U(a) && (a.nodeType ? a[this.expando] = b : Object.defineProperty(a, this.expando, {
                    value: b, configurable: !0
                }))), b
            }, set: function (a, b, c) {
                var d, e = this.cache(a);
                if ("string" == typeof b) e[r.camelCase(b)] = c; else for (d in b) e[r.camelCase(d)] = b[d];
                return e
            }, get: function (a, b) {
                return void 0 === b ? this.cache(a) : a[this.expando] && a[this.expando][r.camelCase(b)]
            }, access: function (a, b, c) {
                return void 0 === b || b && "string" == typeof b && void 0 === c ? this.get(a, b) : (this.set(a, b, c), void 0 !== c ? c : b)
            }, remove: function (a, b) {
                var c, d = a[this.expando];
                if (void 0 !== d) {
                    if (void 0 !== b) {
                        Array.isArray(b) ? b = b.map(r.camelCase) : (b = r.camelCase(b), b = b in d ? [b] : b.match(L) || []), c = b.length;
                        while (c--) delete d[b[c]]
                    }
                    (void 0 === b || r.isEmptyObject(d)) && (a.nodeType ? a[this.expando] = void 0 : delete a[this.expando])
                }
            }, hasData: function (a) {
                var b = a[this.expando];
                return void 0 !== b && !r.isEmptyObject(b)
            }
        };
        var W = new V, X = new V, Y = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, Z = /[A-Z]/g;

        function $(a) {
            return "true" === a || "false" !== a && ("null" === a ? null : a === +a + "" ? +a : Y.test(a) ? JSON.parse(a) : a)
        }

        function _(a, b, c) {
            var d;
            if (void 0 === c && 1 === a.nodeType) if (d = "data-" + b.replace(Z, "-$&").toLowerCase(), c = a.getAttribute(d), "string" == typeof c) {
                try {
                    c = $(c)
                } catch (e) {
                }
                X.set(a, b, c)
            } else c = void 0;
            return c
        }

        r.extend({
            hasData: function (a) {
                return X.hasData(a) || W.hasData(a)
            }, data: function (a, b, c) {
                return X.access(a, b, c)
            }, removeData: function (a, b) {
                X.remove(a, b)
            }, _data: function (a, b, c) {
                return W.access(a, b, c)
            }, _removeData: function (a, b) {
                W.remove(a, b)
            }
        }), r.fn.extend({
            data: function (a, b) {
                var c, d, e, f = this[0], g = f && f.attributes;
                if (void 0 === a) {
                    if (this.length && (e = X.get(f), 1 === f.nodeType && !W.get(f, "hasDataAttrs"))) {
                        c = g.length;
                        while (c--) g[c] && (d = g[c].name, 0 === d.indexOf("data-") && (d = r.camelCase(d.slice(5)), _(f, d, e[d])));
                        W.set(f, "hasDataAttrs", !0)
                    }
                    return e
                }
                return "object" == typeof a ? this.each(function () {
                    X.set(this, a)
                }) : T(this, function (b) {
                    var c;
                    if (f && void 0 === b) {
                        if (c = X.get(f, a), void 0 !== c) return c;
                        if (c = _(f, a), void 0 !== c) return c
                    } else this.each(function () {
                        X.set(this, a, b)
                    })
                }, null, b, arguments.length > 1, null, !0)
            }, removeData: function (a) {
                return this.each(function () {
                    X.remove(this, a)
                })
            }
        }), r.extend({
            queue: function (a, b, c) {
                var d;
                if (a) return b = (b || "fx") + "queue", d = W.get(a, b), c && (!d || Array.isArray(c) ? d = W.access(a, b, r.makeArray(c)) : d.push(c)), d || []
            }, dequeue: function (a, b) {
                b = b || "fx";
                var c = r.queue(a, b), d = c.length, e = c.shift(), f = r._queueHooks(a, b), g = function () {
                    r.dequeue(a, b)
                };
                "inprogress" === e && (e = c.shift(), d--), e && ("fx" === b && c.unshift("inprogress"), delete f.stop, e.call(a, g, f)), !d && f && f.empty.fire()
            }, _queueHooks: function (a, b) {
                var c = b + "queueHooks";
                return W.get(a, c) || W.access(a, c, {
                    empty: r.Callbacks("once memory").add(function () {
                        W.remove(a, [b + "queue", c])
                    })
                })
            }
        }), r.fn.extend({
            queue: function (a, b) {
                var c = 2;
                return "string" != typeof a && (b = a, a = "fx", c--), arguments.length < c ? r.queue(this[0], a) : void 0 === b ? this : this.each(function () {
                    var c = r.queue(this, a, b);
                    r._queueHooks(this, a), "fx" === a && "inprogress" !== c[0] && r.dequeue(this, a)
                })
            }, dequeue: function (a) {
                return this.each(function () {
                    r.dequeue(this, a)
                })
            }, clearQueue: function (a) {
                return this.queue(a || "fx", [])
            }, promise: function (a, b) {
                var c, d = 1, e = r.Deferred(), f = this, g = this.length, h = function () {
                    --d || e.resolveWith(f, [f])
                };
                "string" != typeof a && (b = a, a = void 0), a = a || "fx";
                while (g--) c = W.get(f[g], a + "queueHooks"), c && c.empty && (d++, c.empty.add(h));
                return h(), e.promise(b)
            }
        });
        var aa = /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,
          ba = new RegExp("^(?:([+-])=|)(" + aa + ")([a-z%]*)$", "i"), ca = ["Top", "Right", "Bottom", "Left"],
          da = function (a, b) {
              return a = b || a, "none" === a.style.display || "" === a.style.display && r.contains(a.ownerDocument, a) && "none" === r.css(a, "display")
          }, ea = function (a, b, c, d) {
              var e, f, g = {};
              for (f in b) g[f] = a.style[f], a.style[f] = b[f];
              e = c.apply(a, d || []);
              for (f in b) a.style[f] = g[f];
              return e
          };

        function fa(a, b, c, d) {
            var e, f = 1, g = 20, h = d ? function () {
                  return d.cur()
              } : function () {
                  return r.css(a, b, "")
              }, i = h(), j = c && c[3] || (r.cssNumber[b] ? "" : "px"),
              k = (r.cssNumber[b] || "px" !== j && +i) && ba.exec(r.css(a, b));
            if (k && k[3] !== j) {
                j = j || k[3], c = c || [], k = +i || 1;
                do f = f || ".5", k /= f, r.style(a, b, k + j); while (f !== (f = h() / i) && 1 !== f && --g)
            }
            return c && (k = +k || +i || 0, e = c[1] ? k + (c[1] + 1) * c[2] : +c[2], d && (d.unit = j, d.start = k, d.end = e)), e
        }

        var ga = {};

        function ha(a) {
            var b, c = a.ownerDocument, d = a.nodeName, e = ga[d];
            return e ? e : (b = c.body.appendChild(c.createElement(d)), e = r.css(b, "display"), b.parentNode.removeChild(b), "none" === e && (e = "block"), ga[d] = e, e)
        }

        function ia(a, b) {
            for (var c, d, e = [], f = 0, g = a.length; f < g; f++) d = a[f], d.style && (c = d.style.display, b ? ("none" === c && (e[f] = W.get(d, "display") || null, e[f] || (d.style.display = "")), "" === d.style.display && da(d) && (e[f] = ha(d))) : "none" !== c && (e[f] = "none", W.set(d, "display", c)));
            for (f = 0; f < g; f++) null != e[f] && (a[f].style.display = e[f]);
            return a
        }

        r.fn.extend({
            show: function () {
                return ia(this, !0)
            }, hide: function () {
                return ia(this)
            }, toggle: function (a) {
                return "boolean" == typeof a ? a ? this.show() : this.hide() : this.each(function () {
                    da(this) ? r(this).show() : r(this).hide()
                })
            }
        });
        var ja = /^(?:checkbox|radio)$/i, ka = /<([a-z][^\/\0>\x20\t\r\n\f]+)/i, la = /^$|\/(?:java|ecma)script/i,
          ma = {
              option: [1, "<select multiple='multiple'>", "</select>"], thead: [1, "<table>", "</table>"],
              col: [2, "<table><colgroup>", "</colgroup></table>"], tr: [2, "<table><tbody>", "</tbody></table>"],
              td: [3, "<table><tbody><tr>", "</tr></tbody></table>"], _default: [0, "", ""]
          };
        ma.optgroup = ma.option, ma.tbody = ma.tfoot = ma.colgroup = ma.caption = ma.thead, ma.th = ma.td;

        function na(a, b) {
            var c;
            return c = "undefined" != typeof a.getElementsByTagName ? a.getElementsByTagName(b || "*") : "undefined" != typeof a.querySelectorAll ? a.querySelectorAll(b || "*") : [], void 0 === b || b && B(a, b) ? r.merge([a], c) : c
        }

        function oa(a, b) {
            for (var c = 0, d = a.length; c < d; c++) W.set(a[c], "globalEval", !b || W.get(b[c], "globalEval"))
        }

        var pa = /<|&#?\w+;/;

        function qa(a, b, c, d, e) {
            for (var f, g, h, i, j, k, l = b.createDocumentFragment(), m = [], n = 0, o = a.length; n < o; n++) if (f = a[n], f || 0 === f) if ("object" === r.type(f)) r.merge(m, f.nodeType ? [f] : f); else if (pa.test(f)) {
                g = g || l.appendChild(b.createElement("div")), h = (ka.exec(f) || ["", ""])[1].toLowerCase(), i = ma[h] || ma._default, g.innerHTML = i[1] + r.htmlPrefilter(f) + i[2], k = i[0];
                while (k--) g = g.lastChild;
                r.merge(m, g.childNodes), g = l.firstChild, g.textContent = ""
            } else m.push(b.createTextNode(f));
            l.textContent = "", n = 0;
            while (f = m[n++]) if (d && r.inArray(f, d) > -1) e && e.push(f); else if (j = r.contains(f.ownerDocument, f), g = na(l.appendChild(f), "script"), j && oa(g), c) {
                k = 0;
                while (f = g[k++]) la.test(f.type || "") && c.push(f)
            }
            return l
        }

        !function () {
            var a = d.createDocumentFragment(), b = a.appendChild(d.createElement("div")), c = d.createElement("input");
            c.setAttribute("type", "radio"), c.setAttribute("checked", "checked"), c.setAttribute("name", "t"), b.appendChild(c), o.checkClone = b.cloneNode(!0).cloneNode(!0).lastChild.checked, b.innerHTML = "<textarea>x</textarea>", o.noCloneChecked = !!b.cloneNode(!0).lastChild.defaultValue
        }();
        var ra = d.documentElement, sa = /^key/, ta = /^(?:mouse|pointer|contextmenu|drag|drop)|click/,
          ua = /^([^.]*)(?:\.(.+)|)/;

        function va() {
            return !0
        }

        function wa() {
            return !1
        }

        function xa() {
            try {
                return d.activeElement
            } catch (a) {
            }
        }

        function ya(a, b, c, d, e, f) {
            var g, h;
            if ("object" == typeof b) {
                "string" != typeof c && (d = d || c, c = void 0);
                for (h in b) ya(a, h, c, d, b[h], f);
                return a
            }
            if (null == d && null == e ? (e = c, d = c = void 0) : null == e && ("string" == typeof c ? (e = d, d = void 0) : (e = d, d = c, c = void 0)), e === !1) e = wa; else if (!e) return a;
            return 1 === f && (g = e, e = function (a) {
                return r().off(a), g.apply(this, arguments)
            }, e.guid = g.guid || (g.guid = r.guid++)), a.each(function () {
                r.event.add(this, b, e, d, c)
            })
        }

        r.event = {
            global: {}, add: function (a, b, c, d, e) {
                var f, g, h, i, j, k, l, m, n, o, p, q = W.get(a);
                if (q) {
                    c.handler && (f = c, c = f.handler, e = f.selector), e && r.find.matchesSelector(ra, e), c.guid || (c.guid = r.guid++), (i = q.events) || (i = q.events = {}), (g = q.handle) || (g = q.handle = function (b) {
                        return "undefined" != typeof r && r.event.triggered !== b.type ? r.event.dispatch.apply(a, arguments) : void 0
                    }), b = (b || "").match(L) || [""], j = b.length;
                    while (j--) h = ua.exec(b[j]) || [], n = p = h[1], o = (h[2] || "").split(".").sort(), n && (l = r.event.special[n] || {}, n = (e ? l.delegateType : l.bindType) || n, l = r.event.special[n] || {}, k = r.extend({
                        type: n, origType: p, data: d, handler: c, guid: c.guid, selector: e,
                        needsContext: e && r.expr.match.needsContext.test(e), namespace: o.join(".")
                    }, f), (m = i[n]) || (m = i[n] = [], m.delegateCount = 0, l.setup && l.setup.call(a, d, o, g) !== !1 || a.addEventListener && a.addEventListener(n, g)), l.add && (l.add.call(a, k), k.handler.guid || (k.handler.guid = c.guid)), e ? m.splice(m.delegateCount++, 0, k) : m.push(k), r.event.global[n] = !0)
                }
            }, remove: function (a, b, c, d, e) {
                var f, g, h, i, j, k, l, m, n, o, p, q = W.hasData(a) && W.get(a);
                if (q && (i = q.events)) {
                    b = (b || "").match(L) || [""], j = b.length;
                    while (j--) if (h = ua.exec(b[j]) || [], n = p = h[1], o = (h[2] || "").split(".").sort(), n) {
                        l = r.event.special[n] || {}, n = (d ? l.delegateType : l.bindType) || n, m = i[n] || [], h = h[2] && new RegExp("(^|\\.)" + o.join("\\.(?:.*\\.|)") + "(\\.|$)"), g = f = m.length;
                        while (f--) k = m[f], !e && p !== k.origType || c && c.guid !== k.guid || h && !h.test(k.namespace) || d && d !== k.selector && ("**" !== d || !k.selector) || (m.splice(f, 1), k.selector && m.delegateCount--, l.remove && l.remove.call(a, k));
                        g && !m.length && (l.teardown && l.teardown.call(a, o, q.handle) !== !1 || r.removeEvent(a, n, q.handle), delete i[n])
                    } else for (n in i) r.event.remove(a, n + b[j], c, d, !0);
                    r.isEmptyObject(i) && W.remove(a, "handle events")
                }
            }, dispatch: function (a) {
                var b = r.event.fix(a), c, d, e, f, g, h, i = new Array(arguments.length),
                  j = (W.get(this, "events") || {})[b.type] || [], k = r.event.special[b.type] || {};
                for (i[0] = b, c = 1; c < arguments.length; c++) i[c] = arguments[c];
                if (b.delegateTarget = this, !k.preDispatch || k.preDispatch.call(this, b) !== !1) {
                    h = r.event.handlers.call(this, b, j), c = 0;
                    while ((f = h[c++]) && !b.isPropagationStopped()) {
                        b.currentTarget = f.elem, d = 0;
                        while ((g = f.handlers[d++]) && !b.isImmediatePropagationStopped()) b.rnamespace && !b.rnamespace.test(g.namespace) || (b.handleObj = g, b.data = g.data, e = ((r.event.special[g.origType] || {}).handle || g.handler).apply(f.elem, i), void 0 !== e && (b.result = e) === !1 && (b.preventDefault(), b.stopPropagation()))
                    }
                    return k.postDispatch && k.postDispatch.call(this, b), b.result
                }
            }, handlers: function (a, b) {
                var c, d, e, f, g, h = [], i = b.delegateCount, j = a.target;
                if (i && j.nodeType && !("click" === a.type && a.button >= 1)) for (; j !== this; j = j.parentNode || this) if (1 === j.nodeType && ("click" !== a.type || j.disabled !== !0)) {
                    for (f = [], g = {}, c = 0; c < i; c++) d = b[c], e = d.selector + " ", void 0 === g[e] && (g[e] = d.needsContext ? r(e, this).index(j) > -1 : r.find(e, this, null, [j]).length), g[e] && f.push(d);
                    f.length && h.push({elem: j, handlers: f})
                }
                return j = this, i < b.length && h.push({elem: j, handlers: b.slice(i)}), h
            }, addProp: function (a, b) {
                Object.defineProperty(r.Event.prototype, a, {
                    enumerable: !0, configurable: !0, get: r.isFunction(b) ? function () {
                        if (this.originalEvent) return b(this.originalEvent)
                    } : function () {
                        if (this.originalEvent) return this.originalEvent[a]
                    }, set: function (b) {
                        Object.defineProperty(this, a, {enumerable: !0, configurable: !0, writable: !0, value: b})
                    }
                })
            }, fix: function (a) {
                return a[r.expando] ? a : new r.Event(a)
            }, special: {
                load: {noBubble: !0}, focus: {
                    trigger: function () {
                        if (this !== xa() && this.focus) return this.focus(), !1
                    }, delegateType: "focusin"
                }, blur: {
                    trigger: function () {
                        if (this === xa() && this.blur) return this.blur(), !1
                    }, delegateType: "focusout"
                }, click: {
                    trigger: function () {
                        if ("checkbox" === this.type && this.click && B(this, "input")) return this.click(), !1
                    }, _default: function (a) {
                        return B(a.target, "a")
                    }
                }, beforeunload: {
                    postDispatch: function (a) {
                        void 0 !== a.result && a.originalEvent && (a.originalEvent.returnValue = a.result)
                    }
                }
            }
        }, r.removeEvent = function (a, b, c) {
            a.removeEventListener && a.removeEventListener(b, c)
        }, r.Event = function (a, b) {
            return this instanceof r.Event ? (a && a.type ? (this.originalEvent = a, this.type = a.type, this.isDefaultPrevented = a.defaultPrevented || void 0 === a.defaultPrevented && a.returnValue === !1 ? va : wa, this.target = a.target && 3 === a.target.nodeType ? a.target.parentNode : a.target, this.currentTarget = a.currentTarget, this.relatedTarget = a.relatedTarget) : this.type = a, b && r.extend(this, b), this.timeStamp = a && a.timeStamp || r.now(), void (this[r.expando] = !0)) : new r.Event(a, b)
        }, r.Event.prototype = {
            constructor: r.Event, isDefaultPrevented: wa, isPropagationStopped: wa, isImmediatePropagationStopped: wa,
            isSimulated: !1, preventDefault: function () {
                var a = this.originalEvent;
                this.isDefaultPrevented = va, a && !this.isSimulated && a.preventDefault()
            }, stopPropagation: function () {
                var a = this.originalEvent;
                this.isPropagationStopped = va, a && !this.isSimulated && a.stopPropagation()
            }, stopImmediatePropagation: function () {
                var a = this.originalEvent;
                this.isImmediatePropagationStopped = va, a && !this.isSimulated && a.stopImmediatePropagation(), this.stopPropagation()
            }
        }, r.each({
            altKey: !0, bubbles: !0, cancelable: !0, changedTouches: !0, ctrlKey: !0, detail: !0, eventPhase: !0,
            metaKey: !0, pageX: !0, pageY: !0, shiftKey: !0, view: !0, "char": !0, charCode: !0, key: !0, keyCode: !0,
            button: !0, buttons: !0, clientX: !0, clientY: !0, offsetX: !0, offsetY: !0, pointerId: !0, pointerType: !0,
            screenX: !0, screenY: !0, targetTouches: !0, toElement: !0, touches: !0, which: function (a) {
                var b = a.button;
                return null == a.which && sa.test(a.type) ? null != a.charCode ? a.charCode : a.keyCode : !a.which && void 0 !== b && ta.test(a.type) ? 1 & b ? 1 : 2 & b ? 3 : 4 & b ? 2 : 0 : a.which
            }
        }, r.event.addProp), r.each({
            mouseenter: "mouseover", mouseleave: "mouseout", pointerenter: "pointerover", pointerleave: "pointerout"
        }, function (a, b) {
            r.event.special[a] = {
                delegateType: b, bindType: b, handle: function (a) {
                    var c, d = this, e = a.relatedTarget, f = a.handleObj;
                    return e && (e === d || r.contains(d, e)) || (a.type = f.origType, c = f.handler.apply(this, arguments), a.type = b), c
                }
            }
        }), r.fn.extend({
            on: function (a, b, c, d) {
                return ya(this, a, b, c, d)
            }, one: function (a, b, c, d) {
                return ya(this, a, b, c, d, 1)
            }, off: function (a, b, c) {
                var d, e;
                if (a && a.preventDefault && a.handleObj) return d = a.handleObj, r(a.delegateTarget).off(d.namespace ? d.origType + "." + d.namespace : d.origType, d.selector, d.handler), this;
                if ("object" == typeof a) {
                    for (e in a) this.off(e, b, a[e]);
                    return this
                }
                return b !== !1 && "function" != typeof b || (c = b, b = void 0), c === !1 && (c = wa), this.each(function () {
                    r.event.remove(this, a, c, b)
                })
            }
        });
        var za = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([a-z][^\/\0>\x20\t\r\n\f]*)[^>]*)\/>/gi,
          Aa = /<script|<style|<link/i, Ba = /checked\s*(?:[^=]|=\s*.checked.)/i, Ca = /^true\/(.*)/,
          Da = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g;

        function Ea(a, b) {
            return B(a, "table") && B(11 !== b.nodeType ? b : b.firstChild, "tr") ? r(">tbody", a)[0] || a : a
        }

        function Fa(a) {
            return a.type = (null !== a.getAttribute("type")) + "/" + a.type, a
        }

        function Ga(a) {
            var b = Ca.exec(a.type);
            return b ? a.type = b[1] : a.removeAttribute("type"), a
        }

        function Ha(a, b) {
            var c, d, e, f, g, h, i, j;
            if (1 === b.nodeType) {
                if (W.hasData(a) && (f = W.access(a), g = W.set(b, f), j = f.events)) {
                    delete g.handle, g.events = {};
                    for (e in j) for (c = 0, d = j[e].length; c < d; c++) r.event.add(b, e, j[e][c])
                }
                X.hasData(a) && (h = X.access(a), i = r.extend({}, h), X.set(b, i))
            }
        }

        function Ia(a, b) {
            var c = b.nodeName.toLowerCase();
            "input" === c && ja.test(a.type) ? b.checked = a.checked : "input" !== c && "textarea" !== c || (b.defaultValue = a.defaultValue)
        }

        function Ja(a, b, c, d) {
            b = g.apply([], b);
            var e, f, h, i, j, k, l = 0, m = a.length, n = m - 1, q = b[0], s = r.isFunction(q);
            if (s || m > 1 && "string" == typeof q && !o.checkClone && Ba.test(q)) return a.each(function (e) {
                var f = a.eq(e);
                s && (b[0] = q.call(this, e, f.html())), Ja(f, b, c, d)
            });
            if (m && (e = qa(b, a[0].ownerDocument, !1, a, d), f = e.firstChild, 1 === e.childNodes.length && (e = f), f || d)) {
                for (h = r.map(na(e, "script"), Fa), i = h.length; l < m; l++) j = e, l !== n && (j = r.clone(j, !0, !0), i && r.merge(h, na(j, "script"))), c.call(a[l], j, l);
                if (i) for (k = h[h.length - 1].ownerDocument, r.map(h, Ga), l = 0; l < i; l++) j = h[l], la.test(j.type || "") && !W.access(j, "globalEval") && r.contains(k, j) && (j.src ? r._evalUrl && r._evalUrl(j.src) : p(j.textContent.replace(Da, ""), k))
            }
            return a
        }

        function Ka(a, b, c) {
            for (var d, e = b ? r.filter(b, a) : a, f = 0; null != (d = e[f]); f++) c || 1 !== d.nodeType || r.cleanData(na(d)), d.parentNode && (c && r.contains(d.ownerDocument, d) && oa(na(d, "script")), d.parentNode.removeChild(d));
            return a
        }

        r.extend({
            htmlPrefilter: function (a) {
                return a.replace(za, "<$1></$2>")
            }, clone: function (a, b, c) {
                var d, e, f, g, h = a.cloneNode(!0), i = r.contains(a.ownerDocument, a);
                if (!(o.noCloneChecked || 1 !== a.nodeType && 11 !== a.nodeType || r.isXMLDoc(a))) for (g = na(h), f = na(a), d = 0, e = f.length; d < e; d++) Ia(f[d], g[d]);
                if (b) if (c) for (f = f || na(a), g = g || na(h), d = 0, e = f.length; d < e; d++) Ha(f[d], g[d]); else Ha(a, h);
                return g = na(h, "script"), g.length > 0 && oa(g, !i && na(a, "script")), h
            }, cleanData: function (a) {
                for (var b, c, d, e = r.event.special, f = 0; void 0 !== (c = a[f]); f++) if (U(c)) {
                    if (b = c[W.expando]) {
                        if (b.events) for (d in b.events) e[d] ? r.event.remove(c, d) : r.removeEvent(c, d, b.handle);
                        c[W.expando] = void 0
                    }
                    c[X.expando] && (c[X.expando] = void 0)
                }
            }
        }), r.fn.extend({
            detach: function (a) {
                return Ka(this, a, !0)
            }, remove: function (a) {
                return Ka(this, a)
            }, text: function (a) {
                return T(this, function (a) {
                    return void 0 === a ? r.text(this) : this.empty().each(function () {
                        1 !== this.nodeType && 11 !== this.nodeType && 9 !== this.nodeType || (this.textContent = a)
                    })
                }, null, a, arguments.length)
            }, append: function () {
                return Ja(this, arguments, function (a) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var b = Ea(this, a);
                        b.appendChild(a)
                    }
                })
            }, prepend: function () {
                return Ja(this, arguments, function (a) {
                    if (1 === this.nodeType || 11 === this.nodeType || 9 === this.nodeType) {
                        var b = Ea(this, a);
                        b.insertBefore(a, b.firstChild)
                    }
                })
            }, before: function () {
                return Ja(this, arguments, function (a) {
                    this.parentNode && this.parentNode.insertBefore(a, this)
                })
            }, after: function () {
                return Ja(this, arguments, function (a) {
                    this.parentNode && this.parentNode.insertBefore(a, this.nextSibling)
                })
            }, empty: function () {
                for (var a, b = 0; null != (a = this[b]); b++) 1 === a.nodeType && (r.cleanData(na(a, !1)), a.textContent = "");
                return this
            }, clone: function (a, b) {
                return a = null != a && a, b = null == b ? a : b, this.map(function () {
                    return r.clone(this, a, b)
                })
            }, html: function (a) {
                return T(this, function (a) {
                    var b = this[0] || {}, c = 0, d = this.length;
                    if (void 0 === a && 1 === b.nodeType) return b.innerHTML;
                    if ("string" == typeof a && !Aa.test(a) && !ma[(ka.exec(a) || ["", ""])[1].toLowerCase()]) {
                        a = r.htmlPrefilter(a);
                        try {
                            for (; c < d; c++) b = this[c] || {}, 1 === b.nodeType && (r.cleanData(na(b, !1)), b.innerHTML = a);
                            b = 0
                        } catch (e) {
                        }
                    }
                    b && this.empty().append(a)
                }, null, a, arguments.length)
            }, replaceWith: function () {
                var a = [];
                return Ja(this, arguments, function (b) {
                    var c = this.parentNode;
                    r.inArray(this, a) < 0 && (r.cleanData(na(this)), c && c.replaceChild(b, this))
                }, a)
            }
        }), r.each({
            appendTo: "append", prependTo: "prepend", insertBefore: "before", insertAfter: "after",
            replaceAll: "replaceWith"
        }, function (a, b) {
            r.fn[a] = function (a) {
                for (var c, d = [], e = r(a), f = e.length - 1, g = 0; g <= f; g++) c = g === f ? this : this.clone(!0), r(e[g])[b](c), h.apply(d, c.get());
                return this.pushStack(d)
            }
        });
        var La = /^margin/, Ma = new RegExp("^(" + aa + ")(?!px)[a-z%]+$", "i"), Na = function (b) {
            var c = b.ownerDocument.defaultView;
            return c && c.opener || (c = a), c.getComputedStyle(b)
        };
        !function () {
            function b() {
                if (i) {
                    i.style.cssText = "box-sizing:border-box;position:relative;display:block;margin:auto;border:1px;padding:1px;top:1%;width:50%", i.innerHTML = "", ra.appendChild(h);
                    var b = a.getComputedStyle(i);
                    c = "1%" !== b.top, g = "2px" === b.marginLeft, e = "4px" === b.width, i.style.marginRight = "50%", f = "4px" === b.marginRight, ra.removeChild(h), i = null
                }
            }

            var c, e, f, g, h = d.createElement("div"), i = d.createElement("div");
            i.style && (i.style.backgroundClip = "content-box", i.cloneNode(!0).style.backgroundClip = "", o.clearCloneStyle = "content-box" === i.style.backgroundClip, h.style.cssText = "border:0;width:8px;height:0;top:0;left:-9999px;padding:0;margin-top:1px;position:absolute", h.appendChild(i), r.extend(o, {
                pixelPosition: function () {
                    return b(), c
                }, boxSizingReliable: function () {
                    return b(), e
                }, pixelMarginRight: function () {
                    return b(), f
                }, reliableMarginLeft: function () {
                    return b(), g
                }
            }))
        }();

        function Oa(a, b, c) {
            var d, e, f, g, h = a.style;
            return c = c || Na(a), c && (g = c.getPropertyValue(b) || c[b], "" !== g || r.contains(a.ownerDocument, a) || (g = r.style(a, b)), !o.pixelMarginRight() && Ma.test(g) && La.test(b) && (d = h.width, e = h.minWidth, f = h.maxWidth, h.minWidth = h.maxWidth = h.width = g, g = c.width, h.width = d, h.minWidth = e, h.maxWidth = f)), void 0 !== g ? g + "" : g
        }

        function Pa(a, b) {
            return {
                get: function () {
                    return a() ? void delete this.get : (this.get = b).apply(this, arguments)
                }
            }
        }

        var Qa = /^(none|table(?!-c[ea]).+)/, Ra = /^--/,
          Sa = {position: "absolute", visibility: "hidden", display: "block"},
          Ta = {letterSpacing: "0", fontWeight: "400"}, Ua = ["Webkit", "Moz", "ms"],
          Va = d.createElement("div").style;

        function Wa(a) {
            if (a in Va) return a;
            var b = a[0].toUpperCase() + a.slice(1), c = Ua.length;
            while (c--) if (a = Ua[c] + b, a in Va) return a
        }

        function Xa(a) {
            var b = r.cssProps[a];
            return b || (b = r.cssProps[a] = Wa(a) || a), b
        }

        function Ya(a, b, c) {
            var d = ba.exec(b);
            return d ? Math.max(0, d[2] - (c || 0)) + (d[3] || "px") : b
        }

        function Za(a, b, c, d, e) {
            var f, g = 0;
            for (f = c === (d ? "border" : "content") ? 4 : "width" === b ? 1 : 0; f < 4; f += 2) "margin" === c && (g += r.css(a, c + ca[f], !0, e)), d ? ("content" === c && (g -= r.css(a, "padding" + ca[f], !0, e)), "margin" !== c && (g -= r.css(a, "border" + ca[f] + "Width", !0, e))) : (g += r.css(a, "padding" + ca[f], !0, e), "padding" !== c && (g += r.css(a, "border" + ca[f] + "Width", !0, e)));
            return g
        }

        function $a(a, b, c) {
            var d, e = Na(a), f = Oa(a, b, e), g = "border-box" === r.css(a, "boxSizing", !1, e);
            return Ma.test(f) ? f : (d = g && (o.boxSizingReliable() || f === a.style[b]), "auto" === f && (f = a["offset" + b[0].toUpperCase() + b.slice(1)]), f = parseFloat(f) || 0, f + Za(a, b, c || (g ? "border" : "content"), d, e) + "px")
        }

        r.extend({
            cssHooks: {
                opacity: {
                    get: function (a, b) {
                        if (b) {
                            var c = Oa(a, "opacity");
                            return "" === c ? "1" : c
                        }
                    }
                }
            }, cssNumber: {
                animationIterationCount: !0, columnCount: !0, fillOpacity: !0, flexGrow: !0, flexShrink: !0,
                fontWeight: !0, lineHeight: !0, opacity: !0, order: !0, orphans: !0, widows: !0, zIndex: !0, zoom: !0
            }, cssProps: {"float": "cssFloat"}, style: function (a, b, c, d) {
                if (a && 3 !== a.nodeType && 8 !== a.nodeType && a.style) {
                    var e, f, g, h = r.camelCase(b), i = Ra.test(b), j = a.style;
                    return i || (b = Xa(h)), g = r.cssHooks[b] || r.cssHooks[h], void 0 === c ? g && "get" in g && void 0 !== (e = g.get(a, !1, d)) ? e : j[b] : (f = typeof c, "string" === f && (e = ba.exec(c)) && e[1] && (c = fa(a, b, e), f = "number"), null != c && c === c && ("number" === f && (c += e && e[3] || (r.cssNumber[h] ? "" : "px")), o.clearCloneStyle || "" !== c || 0 !== b.indexOf("background") || (j[b] = "inherit"), g && "set" in g && void 0 === (c = g.set(a, c, d)) || (i ? j.setProperty(b, c) : j[b] = c)), void 0)
                }
            }, css: function (a, b, c, d) {
                var e, f, g, h = r.camelCase(b), i = Ra.test(b);
                return i || (b = Xa(h)), g = r.cssHooks[b] || r.cssHooks[h], g && "get" in g && (e = g.get(a, !0, c)), void 0 === e && (e = Oa(a, b, d)), "normal" === e && b in Ta && (e = Ta[b]), "" === c || c ? (f = parseFloat(e), c === !0 || isFinite(f) ? f || 0 : e) : e
            }
        }), r.each(["height", "width"], function (a, b) {
            r.cssHooks[b] = {
                get: function (a, c, d) {
                    if (c) return !Qa.test(r.css(a, "display")) || a.getClientRects().length && a.getBoundingClientRect().width ? $a(a, b, d) : ea(a, Sa, function () {
                        return $a(a, b, d)
                    })
                }, set: function (a, c, d) {
                    var e, f = d && Na(a), g = d && Za(a, b, d, "border-box" === r.css(a, "boxSizing", !1, f), f);
                    return g && (e = ba.exec(c)) && "px" !== (e[3] || "px") && (a.style[b] = c, c = r.css(a, b)), Ya(a, c, g)
                }
            }
        }), r.cssHooks.marginLeft = Pa(o.reliableMarginLeft, function (a, b) {
            if (b) return (parseFloat(Oa(a, "marginLeft")) || a.getBoundingClientRect().left - ea(a, {marginLeft: 0}, function () {
                return a.getBoundingClientRect().left
            })) + "px"
        }), r.each({margin: "", padding: "", border: "Width"}, function (a, b) {
            r.cssHooks[a + b] = {
                expand: function (c) {
                    for (var d = 0, e = {}, f = "string" == typeof c ? c.split(" ") : [c]; d < 4; d++) e[a + ca[d] + b] = f[d] || f[d - 2] || f[0];
                    return e
                }
            }, La.test(a) || (r.cssHooks[a + b].set = Ya)
        }), r.fn.extend({
            css: function (a, b) {
                return T(this, function (a, b, c) {
                    var d, e, f = {}, g = 0;
                    if (Array.isArray(b)) {
                        for (d = Na(a), e = b.length; g < e; g++) f[b[g]] = r.css(a, b[g], !1, d);
                        return f
                    }
                    return void 0 !== c ? r.style(a, b, c) : r.css(a, b)
                }, a, b, arguments.length > 1)
            }
        });

        function _a(a, b, c, d, e) {
            return new _a.prototype.init(a, b, c, d, e)
        }

        r.Tween = _a, _a.prototype = {
            constructor: _a, init: function (a, b, c, d, e, f) {
                this.elem = a, this.prop = c, this.easing = e || r.easing._default, this.options = b, this.start = this.now = this.cur(), this.end = d, this.unit = f || (r.cssNumber[c] ? "" : "px")
            }, cur: function () {
                var a = _a.propHooks[this.prop];
                return a && a.get ? a.get(this) : _a.propHooks._default.get(this)
            }, run: function (a) {
                var b, c = _a.propHooks[this.prop];
                return this.options.duration ? this.pos = b = r.easing[this.easing](a, this.options.duration * a, 0, 1, this.options.duration) : this.pos = b = a, this.now = (this.end - this.start) * b + this.start, this.options.step && this.options.step.call(this.elem, this.now, this), c && c.set ? c.set(this) : _a.propHooks._default.set(this), this
            }
        }, _a.prototype.init.prototype = _a.prototype, _a.propHooks = {
            _default: {
                get: function (a) {
                    var b;
                    return 1 !== a.elem.nodeType || null != a.elem[a.prop] && null == a.elem.style[a.prop] ? a.elem[a.prop] : (b = r.css(a.elem, a.prop, ""), b && "auto" !== b ? b : 0)
                }, set: function (a) {
                    r.fx.step[a.prop] ? r.fx.step[a.prop](a) : 1 !== a.elem.nodeType || null == a.elem.style[r.cssProps[a.prop]] && !r.cssHooks[a.prop] ? a.elem[a.prop] = a.now : r.style(a.elem, a.prop, a.now + a.unit)
                }
            }
        }, _a.propHooks.scrollTop = _a.propHooks.scrollLeft = {
            set: function (a) {
                a.elem.nodeType && a.elem.parentNode && (a.elem[a.prop] = a.now)
            }
        }, r.easing = {
            linear: function (a) {
                return a
            }, swing: function (a) {
                return .5 - Math.cos(a * Math.PI) / 2
            }, _default: "swing"
        }, r.fx = _a.prototype.init, r.fx.step = {};
        var ab, bb, cb = /^(?:toggle|show|hide)$/, db = /queueHooks$/;

        function eb() {
            bb && (d.hidden === !1 && a.requestAnimationFrame ? a.requestAnimationFrame(eb) : a.setTimeout(eb, r.fx.interval), r.fx.tick())
        }

        function fb() {
            return a.setTimeout(function () {
                ab = void 0
            }), ab = r.now()
        }

        function gb(a, b) {
            var c, d = 0, e = {height: a};
            for (b = b ? 1 : 0; d < 4; d += 2 - b) c = ca[d], e["margin" + c] = e["padding" + c] = a;
            return b && (e.opacity = e.width = a), e
        }

        function hb(a, b, c) {
            for (var d, e = (kb.tweeners[b] || []).concat(kb.tweeners["*"]), f = 0, g = e.length; f < g; f++) if (d = e[f].call(c, b, a)) return d
        }

        function ib(a, b, c) {
            var d, e, f, g, h, i, j, k, l = "width" in b || "height" in b, m = this, n = {}, o = a.style,
              p = a.nodeType && da(a), q = W.get(a, "fxshow");
            c.queue || (g = r._queueHooks(a, "fx"), null == g.unqueued && (g.unqueued = 0, h = g.empty.fire, g.empty.fire = function () {
                g.unqueued || h()
            }), g.unqueued++, m.always(function () {
                m.always(function () {
                    g.unqueued--, r.queue(a, "fx").length || g.empty.fire()
                })
            }));
            for (d in b) if (e = b[d], cb.test(e)) {
                if (delete b[d], f = f || "toggle" === e, e === (p ? "hide" : "show")) {
                    if ("show" !== e || !q || void 0 === q[d]) continue;
                    p = !0
                }
                n[d] = q && q[d] || r.style(a, d)
            }
            if (i = !r.isEmptyObject(b), i || !r.isEmptyObject(n)) {
                l && 1 === a.nodeType && (c.overflow = [o.overflow, o.overflowX, o.overflowY], j = q && q.display, null == j && (j = W.get(a, "display")), k = r.css(a, "display"), "none" === k && (j ? k = j : (ia([a], !0), j = a.style.display || j, k = r.css(a, "display"), ia([a]))), ("inline" === k || "inline-block" === k && null != j) && "none" === r.css(a, "float") && (i || (m.done(function () {
                    o.display = j
                }), null == j && (k = o.display, j = "none" === k ? "" : k)), o.display = "inline-block")), c.overflow && (o.overflow = "hidden", m.always(function () {
                    o.overflow = c.overflow[0], o.overflowX = c.overflow[1], o.overflowY = c.overflow[2]
                })), i = !1;
                for (d in n) i || (q ? "hidden" in q && (p = q.hidden) : q = W.access(a, "fxshow", {display: j}), f && (q.hidden = !p), p && ia([a], !0), m.done(function () {
                    p || ia([a]), W.remove(a, "fxshow");
                    for (d in n) r.style(a, d, n[d])
                })), i = hb(p ? q[d] : 0, d, m), d in q || (q[d] = i.start, p && (i.end = i.start, i.start = 0))
            }
        }

        function jb(a, b) {
            var c, d, e, f, g;
            for (c in a) if (d = r.camelCase(c), e = b[d], f = a[c], Array.isArray(f) && (e = f[1], f = a[c] = f[0]), c !== d && (a[d] = f, delete a[c]), g = r.cssHooks[d], g && "expand" in g) {
                f = g.expand(f), delete a[d];
                for (c in f) c in a || (a[c] = f[c], b[c] = e)
            } else b[d] = e
        }

        function kb(a, b, c) {
            var d, e, f = 0, g = kb.prefilters.length, h = r.Deferred().always(function () {
                delete i.elem
            }), i = function () {
                if (e) return !1;
                for (var b = ab || fb(), c = Math.max(0, j.startTime + j.duration - b), d = c / j.duration || 0, f = 1 - d, g = 0, i = j.tweens.length; g < i; g++) j.tweens[g].run(f);
                return h.notifyWith(a, [j, f, c]), f < 1 && i ? c : (i || h.notifyWith(a, [j, 1, 0]), h.resolveWith(a, [j]), !1)
            }, j = h.promise({
                elem: a, props: r.extend({}, b), opts: r.extend(!0, {specialEasing: {}, easing: r.easing._default}, c),
                originalProperties: b, originalOptions: c, startTime: ab || fb(), duration: c.duration, tweens: [],
                createTween: function (b, c) {
                    var d = r.Tween(a, j.opts, b, c, j.opts.specialEasing[b] || j.opts.easing);
                    return j.tweens.push(d), d
                }, stop: function (b) {
                    var c = 0, d = b ? j.tweens.length : 0;
                    if (e) return this;
                    for (e = !0; c < d; c++) j.tweens[c].run(1);
                    return b ? (h.notifyWith(a, [j, 1, 0]), h.resolveWith(a, [j, b])) : h.rejectWith(a, [j, b]), this
                }
            }), k = j.props;
            for (jb(k, j.opts.specialEasing); f < g; f++) if (d = kb.prefilters[f].call(j, a, k, j.opts)) return r.isFunction(d.stop) && (r._queueHooks(j.elem, j.opts.queue).stop = r.proxy(d.stop, d)), d;
            return r.map(k, hb, j), r.isFunction(j.opts.start) && j.opts.start.call(a, j), j.progress(j.opts.progress).done(j.opts.done, j.opts.complete).fail(j.opts.fail).always(j.opts.always), r.fx.timer(r.extend(i, {
                elem: a, anim: j, queue: j.opts.queue
            })), j
        }

        r.Animation = r.extend(kb, {
            tweeners: {
                "*": [function (a, b) {
                    var c = this.createTween(a, b);
                    return fa(c.elem, a, ba.exec(b), c), c
                }]
            }, tweener: function (a, b) {
                r.isFunction(a) ? (b = a, a = ["*"]) : a = a.match(L);
                for (var c, d = 0, e = a.length; d < e; d++) c = a[d], kb.tweeners[c] = kb.tweeners[c] || [], kb.tweeners[c].unshift(b)
            }, prefilters: [ib], prefilter: function (a, b) {
                b ? kb.prefilters.unshift(a) : kb.prefilters.push(a)
            }
        }), r.speed = function (a, b, c) {
            var d = a && "object" == typeof a ? r.extend({}, a) : {
                complete: c || !c && b || r.isFunction(a) && a, duration: a,
                easing: c && b || b && !r.isFunction(b) && b
            };
            return r.fx.off ? d.duration = 0 : "number" != typeof d.duration && (d.duration in r.fx.speeds ? d.duration = r.fx.speeds[d.duration] : d.duration = r.fx.speeds._default), null != d.queue && d.queue !== !0 || (d.queue = "fx"), d.old = d.complete, d.complete = function () {
                r.isFunction(d.old) && d.old.call(this), d.queue && r.dequeue(this, d.queue)
            }, d
        }, r.fn.extend({
            fadeTo: function (a, b, c, d) {
                return this.filter(da).css("opacity", 0).show().end().animate({opacity: b}, a, c, d)
            }, animate: function (a, b, c, d) {
                var e = r.isEmptyObject(a), f = r.speed(b, c, d), g = function () {
                    var b = kb(this, r.extend({}, a), f);
                    (e || W.get(this, "finish")) && b.stop(!0)
                };
                return g.finish = g, e || f.queue === !1 ? this.each(g) : this.queue(f.queue, g)
            }, stop: function (a, b, c) {
                var d = function (a) {
                    var b = a.stop;
                    delete a.stop, b(c)
                };
                return "string" != typeof a && (c = b, b = a, a = void 0), b && a !== !1 && this.queue(a || "fx", []), this.each(function () {
                    var b = !0, e = null != a && a + "queueHooks", f = r.timers, g = W.get(this);
                    if (e) g[e] && g[e].stop && d(g[e]); else for (e in g) g[e] && g[e].stop && db.test(e) && d(g[e]);
                    for (e = f.length; e--;) f[e].elem !== this || null != a && f[e].queue !== a || (f[e].anim.stop(c), b = !1, f.splice(e, 1));
                    !b && c || r.dequeue(this, a)
                })
            }, finish: function (a) {
                return a !== !1 && (a = a || "fx"), this.each(function () {
                    var b, c = W.get(this), d = c[a + "queue"], e = c[a + "queueHooks"], f = r.timers,
                      g = d ? d.length : 0;
                    for (c.finish = !0, r.queue(this, a, []), e && e.stop && e.stop.call(this, !0), b = f.length; b--;) f[b].elem === this && f[b].queue === a && (f[b].anim.stop(!0), f.splice(b, 1));
                    for (b = 0; b < g; b++) d[b] && d[b].finish && d[b].finish.call(this);
                    delete c.finish
                })
            }
        }), r.each(["toggle", "show", "hide"], function (a, b) {
            var c = r.fn[b];
            r.fn[b] = function (a, d, e) {
                return null == a || "boolean" == typeof a ? c.apply(this, arguments) : this.animate(gb(b, !0), a, d, e)
            }
        }), r.each({
            slideDown: gb("show"), slideUp: gb("hide"), slideToggle: gb("toggle"), fadeIn: {opacity: "show"},
            fadeOut: {opacity: "hide"}, fadeToggle: {opacity: "toggle"}
        }, function (a, b) {
            r.fn[a] = function (a, c, d) {
                return this.animate(b, a, c, d)
            }
        }), r.timers = [], r.fx.tick = function () {
            var a, b = 0, c = r.timers;
            for (ab = r.now(); b < c.length; b++) a = c[b], a() || c[b] !== a || c.splice(b--, 1);
            c.length || r.fx.stop(), ab = void 0
        }, r.fx.timer = function (a) {
            r.timers.push(a), r.fx.start()
        }, r.fx.interval = 13, r.fx.start = function () {
            bb || (bb = !0, eb())
        }, r.fx.stop = function () {
            bb = null
        }, r.fx.speeds = {slow: 600, fast: 200, _default: 400}, r.fn.delay = function (b, c) {
            return b = r.fx ? r.fx.speeds[b] || b : b, c = c || "fx", this.queue(c, function (c, d) {
                var e = a.setTimeout(c, b);
                d.stop = function () {
                    a.clearTimeout(e)
                }
            })
        }, function () {
            var a = d.createElement("input"), b = d.createElement("select"),
              c = b.appendChild(d.createElement("option"));
            a.type = "checkbox", o.checkOn = "" !== a.value, o.optSelected = c.selected, a = d.createElement("input"), a.value = "t", a.type = "radio", o.radioValue = "t" === a.value
        }();
        var lb, mb = r.expr.attrHandle;
        r.fn.extend({
            attr: function (a, b) {
                return T(this, r.attr, a, b, arguments.length > 1)
            }, removeAttr: function (a) {
                return this.each(function () {
                    r.removeAttr(this, a)
                })
            }
        }), r.extend({
            attr: function (a, b, c) {
                var d, e, f = a.nodeType;
                if (3 !== f && 8 !== f && 2 !== f) return "undefined" == typeof a.getAttribute ? r.prop(a, b, c) : (1 === f && r.isXMLDoc(a) || (e = r.attrHooks[b.toLowerCase()] || (r.expr.match.bool.test(b) ? lb : void 0)), void 0 !== c ? null === c ? void r.removeAttr(a, b) : e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d : (a.setAttribute(b, c + ""), c) : e && "get" in e && null !== (d = e.get(a, b)) ? d : (d = r.find.attr(a, b),
                  null == d ? void 0 : d))
            }, attrHooks: {
                type: {
                    set: function (a, b) {
                        if (!o.radioValue && "radio" === b && B(a, "input")) {
                            var c = a.value;
                            return a.setAttribute("type", b), c && (a.value = c), b
                        }
                    }
                }
            }, removeAttr: function (a, b) {
                var c, d = 0, e = b && b.match(L);
                if (e && 1 === a.nodeType) while (c = e[d++]) a.removeAttribute(c)
            }
        }), lb = {
            set: function (a, b, c) {
                return b === !1 ? r.removeAttr(a, c) : a.setAttribute(c, c), c
            }
        }, r.each(r.expr.match.bool.source.match(/\w+/g), function (a, b) {
            var c = mb[b] || r.find.attr;
            mb[b] = function (a, b, d) {
                var e, f, g = b.toLowerCase();
                return d || (f = mb[g], mb[g] = e, e = null != c(a, b, d) ? g : null, mb[g] = f), e
            }
        });
        var nb = /^(?:input|select|textarea|button)$/i, ob = /^(?:a|area)$/i;
        r.fn.extend({
            prop: function (a, b) {
                return T(this, r.prop, a, b, arguments.length > 1)
            }, removeProp: function (a) {
                return this.each(function () {
                    delete this[r.propFix[a] || a]
                })
            }
        }), r.extend({
            prop: function (a, b, c) {
                var d, e, f = a.nodeType;
                if (3 !== f && 8 !== f && 2 !== f) return 1 === f && r.isXMLDoc(a) || (b = r.propFix[b] || b, e = r.propHooks[b]), void 0 !== c ? e && "set" in e && void 0 !== (d = e.set(a, c, b)) ? d : a[b] = c : e && "get" in e && null !== (d = e.get(a, b)) ? d : a[b]
            }, propHooks: {
                tabIndex: {
                    get: function (a) {
                        var b = r.find.attr(a, "tabindex");
                        return b ? parseInt(b, 10) : nb.test(a.nodeName) || ob.test(a.nodeName) && a.href ? 0 : -1
                    }
                }
            }, propFix: {"for": "htmlFor", "class": "className"}
        }), o.optSelected || (r.propHooks.selected = {
            get: function (a) {
                var b = a.parentNode;
                return b && b.parentNode && b.parentNode.selectedIndex, null
            }, set: function (a) {
                var b = a.parentNode;
                b && (b.selectedIndex, b.parentNode && b.parentNode.selectedIndex)
            }
        }), r.each(["tabIndex", "readOnly", "maxLength", "cellSpacing", "cellPadding", "rowSpan", "colSpan", "useMap", "frameBorder", "contentEditable"], function () {
            r.propFix[this.toLowerCase()] = this
        });

        function pb(a) {
            var b = a.match(L) || [];
            return b.join(" ")
        }

        function qb(a) {
            return a.getAttribute && a.getAttribute("class") || ""
        }

        r.fn.extend({
            addClass: function (a) {
                var b, c, d, e, f, g, h, i = 0;
                if (r.isFunction(a)) return this.each(function (b) {
                    r(this).addClass(a.call(this, b, qb(this)))
                });
                if ("string" == typeof a && a) {
                    b = a.match(L) || [];
                    while (c = this[i++]) if (e = qb(c), d = 1 === c.nodeType && " " + pb(e) + " ") {
                        g = 0;
                        while (f = b[g++]) d.indexOf(" " + f + " ") < 0 && (d += f + " ");
                        h = pb(d), e !== h && c.setAttribute("class", h)
                    }
                }
                return this
            }, removeClass: function (a) {
                var b, c, d, e, f, g, h, i = 0;
                if (r.isFunction(a)) return this.each(function (b) {
                    r(this).removeClass(a.call(this, b, qb(this)))
                });
                if (!arguments.length) return this.attr("class", "");
                if ("string" == typeof a && a) {
                    b = a.match(L) || [];
                    while (c = this[i++]) if (e = qb(c), d = 1 === c.nodeType && " " + pb(e) + " ") {
                        g = 0;
                        while (f = b[g++]) while (d.indexOf(" " + f + " ") > -1) d = d.replace(" " + f + " ", " ");
                        h = pb(d), e !== h && c.setAttribute("class", h)
                    }
                }
                return this
            }, toggleClass: function (a, b) {
                var c = typeof a;
                return "boolean" == typeof b && "string" === c ? b ? this.addClass(a) : this.removeClass(a) : r.isFunction(a) ? this.each(function (c) {
                    r(this).toggleClass(a.call(this, c, qb(this), b), b)
                }) : this.each(function () {
                    var b, d, e, f;
                    if ("string" === c) {
                        d = 0, e = r(this), f = a.match(L) || [];
                        while (b = f[d++]) e.hasClass(b) ? e.removeClass(b) : e.addClass(b)
                    } else void 0 !== a && "boolean" !== c || (b = qb(this), b && W.set(this, "__className__", b), this.setAttribute && this.setAttribute("class", b || a === !1 ? "" : W.get(this, "__className__") || ""))
                })
            }, hasClass: function (a) {
                var b, c, d = 0;
                b = " " + a + " ";
                while (c = this[d++]) if (1 === c.nodeType && (" " + pb(qb(c)) + " ").indexOf(b) > -1) return !0;
                return !1
            }
        });
        var rb = /\r/g;
        r.fn.extend({
            val: function (a) {
                var b, c, d, e = this[0];
                {
                    if (arguments.length) return d = r.isFunction(a), this.each(function (c) {
                        var e;
                        1 === this.nodeType && (e = d ? a.call(this, c, r(this).val()) : a, null == e ? e = "" : "number" == typeof e ? e += "" : Array.isArray(e) && (e = r.map(e, function (a) {
                            return null == a ? "" : a + ""
                        })), b = r.valHooks[this.type] || r.valHooks[this.nodeName.toLowerCase()], b && "set" in b && void 0 !== b.set(this, e, "value") || (this.value = e))
                    });
                    if (e) return b = r.valHooks[e.type] || r.valHooks[e.nodeName.toLowerCase()], b && "get" in b && void 0 !== (c = b.get(e, "value")) ? c : (c = e.value, "string" == typeof c ? c.replace(rb, "") : null == c ? "" : c)
                }
            }
        }), r.extend({
            valHooks: {
                option: {
                    get: function (a) {
                        var b = r.find.attr(a, "value");
                        return null != b ? b : pb(r.text(a))
                    }
                }, select: {
                    get: function (a) {
                        var b, c, d, e = a.options, f = a.selectedIndex, g = "select-one" === a.type, h = g ? null : [],
                          i = g ? f + 1 : e.length;
                        for (d = f < 0 ? i : g ? f : 0; d < i; d++) if (c = e[d], (c.selected || d === f) && !c.disabled && (!c.parentNode.disabled || !B(c.parentNode, "optgroup"))) {
                            if (b = r(c).val(), g) return b;
                            h.push(b)
                        }
                        return h
                    }, set: function (a, b) {
                        var c, d, e = a.options, f = r.makeArray(b), g = e.length;
                        while (g--) d = e[g], (d.selected = r.inArray(r.valHooks.option.get(d), f) > -1) && (c = !0);
                        return c || (a.selectedIndex = -1), f
                    }
                }
            }
        }), r.each(["radio", "checkbox"], function () {
            r.valHooks[this] = {
                set: function (a, b) {
                    if (Array.isArray(b)) return a.checked = r.inArray(r(a).val(), b) > -1
                }
            }, o.checkOn || (r.valHooks[this].get = function (a) {
                return null === a.getAttribute("value") ? "on" : a.value
            })
        });
        var sb = /^(?:focusinfocus|focusoutblur)$/;
        r.extend(r.event, {
            trigger: function (b, c, e, f) {
                var g, h, i, j, k, m, n, o = [e || d], p = l.call(b, "type") ? b.type : b,
                  q = l.call(b, "namespace") ? b.namespace.split(".") : [];
                if (h = i = e = e || d, 3 !== e.nodeType && 8 !== e.nodeType && !sb.test(p + r.event.triggered) && (p.indexOf(".") > -1 && (q = p.split("."), p = q.shift(), q.sort()), k = p.indexOf(":") < 0 && "on" + p, b = b[r.expando] ? b : new r.Event(p, "object" == typeof b && b), b.isTrigger = f ? 2 : 3, b.namespace = q.join("."), b.rnamespace = b.namespace ? new RegExp("(^|\\.)" + q.join("\\.(?:.*\\.|)") + "(\\.|$)") : null, b.result = void 0, b.target || (b.target = e), c = null == c ? [b] : r.makeArray(c, [b]), n = r.event.special[p] || {}, f || !n.trigger || n.trigger.apply(e, c) !== !1)) {
                    if (!f && !n.noBubble && !r.isWindow(e)) {
                        for (j = n.delegateType || p, sb.test(j + p) || (h = h.parentNode); h; h = h.parentNode) o.push(h), i = h;
                        i === (e.ownerDocument || d) && o.push(i.defaultView || i.parentWindow || a)
                    }
                    g = 0;
                    while ((h = o[g++]) && !b.isPropagationStopped()) b.type = g > 1 ? j : n.bindType || p, m = (W.get(h, "events") || {})[b.type] && W.get(h, "handle"), m && m.apply(h, c), m = k && h[k], m && m.apply && U(h) && (b.result = m.apply(h, c), b.result === !1 && b.preventDefault());
                    return b.type = p, f || b.isDefaultPrevented() || n._default && n._default.apply(o.pop(), c) !== !1 || !U(e) || k && r.isFunction(e[p]) && !r.isWindow(e) && (i = e[k], i && (e[k] = null), r.event.triggered = p, e[p](), r.event.triggered = void 0, i && (e[k] = i)), b.result
                }
            }, simulate: function (a, b, c) {
                var d = r.extend(new r.Event, c, {type: a, isSimulated: !0});
                r.event.trigger(d, null, b)
            }
        }), r.fn.extend({
            trigger: function (a, b) {
                return this.each(function () {
                    r.event.trigger(a, b, this)
                })
            }, triggerHandler: function (a, b) {
                var c = this[0];
                if (c) return r.event.trigger(a, b, c, !0)
            }
        }), r.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "), function (a, b) {
            r.fn[b] = function (a, c) {
                return arguments.length > 0 ? this.on(b, null, a, c) : this.trigger(b)
            }
        }), r.fn.extend({
            hover: function (a, b) {
                return this.mouseenter(a).mouseleave(b || a)
            }
        }), o.focusin = "onfocusin" in a, o.focusin || r.each({focus: "focusin", blur: "focusout"}, function (a, b) {
            var c = function (a) {
                r.event.simulate(b, a.target, r.event.fix(a))
            };
            r.event.special[b] = {
                setup: function () {
                    var d = this.ownerDocument || this, e = W.access(d, b);
                    e || d.addEventListener(a, c, !0), W.access(d, b, (e || 0) + 1)
                }, teardown: function () {
                    var d = this.ownerDocument || this, e = W.access(d, b) - 1;
                    e ? W.access(d, b, e) : (d.removeEventListener(a, c, !0), W.remove(d, b))
                }
            }
        });
        var tb = a.location, ub = r.now(), vb = /\?/;
        r.parseXML = function (b) {
            var c;
            if (!b || "string" != typeof b) return null;
            try {
                c = (new a.DOMParser).parseFromString(b, "text/xml")
            } catch (d) {
                c = void 0
            }
            return c && !c.getElementsByTagName("parsererror").length || r.error("Invalid XML: " + b), c
        };
        var wb = /\[\]$/, xb = /\r?\n/g, yb = /^(?:submit|button|image|reset|file)$/i,
          zb = /^(?:input|select|textarea|keygen)/i;

        function Ab(a, b, c, d) {
            var e;
            if (Array.isArray(b)) r.each(b, function (b, e) {
                c || wb.test(a) ? d(a, e) : Ab(a + "[" + ("object" == typeof e && null != e ? b : "") + "]", e, c, d)
            }); else if (c || "object" !== r.type(b)) d(a, b); else for (e in b) Ab(a + "[" + e + "]", b[e], c, d)
        }

        r.param = function (a, b) {
            var c, d = [], e = function (a, b) {
                var c = r.isFunction(b) ? b() : b;
                d[d.length] = encodeURIComponent(a) + "=" + encodeURIComponent(null == c ? "" : c)
            };
            if (Array.isArray(a) || a.jquery && !r.isPlainObject(a)) r.each(a, function () {
                e(this.name, this.value)
            }); else for (c in a) Ab(c, a[c], b, e);
            return d.join("&")
        }, r.fn.extend({
            serialize: function () {
                return r.param(this.serializeArray())
            }, serializeArray: function () {
                return this.map(function () {
                    var a = r.prop(this, "elements");
                    return a ? r.makeArray(a) : this
                }).filter(function () {
                    var a = this.type;
                    return this.name && !r(this).is(":disabled") && zb.test(this.nodeName) && !yb.test(a) && (this.checked || !ja.test(a))
                }).map(function (a, b) {
                    var c = r(this).val();
                    return null == c ? null : Array.isArray(c) ? r.map(c, function (a) {
                        return {name: b.name, value: a.replace(xb, "\r\n")}
                    }) : {name: b.name, value: c.replace(xb, "\r\n")}
                }).get()
            }
        });
        var Bb = /%20/g, Cb = /#.*$/, Db = /([?&])_=[^&]*/, Eb = /^(.*?):[ \t]*([^\r\n]*)$/gm,
          Fb = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/, Gb = /^(?:GET|HEAD)$/, Hb = /^\/\//,
          Ib = {}, Jb = {}, Kb = "*/".concat("*"), Lb = d.createElement("a");
        Lb.href = tb.href;

        function Mb(a) {
            return function (b, c) {
                "string" != typeof b && (c = b, b = "*");
                var d, e = 0, f = b.toLowerCase().match(L) || [];
                if (r.isFunction(c)) while (d = f[e++]) "+" === d[0] ? (d = d.slice(1) || "*", (a[d] = a[d] || []).unshift(c)) : (a[d] = a[d] || []).push(c)
            }
        }

        function Nb(a, b, c, d) {
            var e = {}, f = a === Jb;

            function g(h) {
                var i;
                return e[h] = !0, r.each(a[h] || [], function (a, h) {
                    var j = h(b, c, d);
                    return "string" != typeof j || f || e[j] ? f ? !(i = j) : void 0 : (b.dataTypes.unshift(j), g(j), !1)
                }), i
            }

            return g(b.dataTypes[0]) || !e["*"] && g("*")
        }

        function Ob(a, b) {
            var c, d, e = r.ajaxSettings.flatOptions || {};
            for (c in b) void 0 !== b[c] && ((e[c] ? a : d || (d = {}))[c] = b[c]);
            return d && r.extend(!0, a, d), a
        }

        function Pb(a, b, c) {
            var d, e, f, g, h = a.contents, i = a.dataTypes;
            while ("*" === i[0]) i.shift(), void 0 === d && (d = a.mimeType || b.getResponseHeader("Content-Type"));
            if (d) for (e in h) if (h[e] && h[e].test(d)) {
                i.unshift(e);
                break
            }
            if (i[0] in c) f = i[0]; else {
                for (e in c) {
                    if (!i[0] || a.converters[e + " " + i[0]]) {
                        f = e;
                        break
                    }
                    g || (g = e)
                }
                f = f || g
            }
            if (f) return f !== i[0] && i.unshift(f), c[f]
        }

        function Qb(a, b, c, d) {
            var e, f, g, h, i, j = {}, k = a.dataTypes.slice();
            if (k[1]) for (g in a.converters) j[g.toLowerCase()] = a.converters[g];
            f = k.shift();
            while (f) if (a.responseFields[f] && (c[a.responseFields[f]] = b), !i && d && a.dataFilter && (b = a.dataFilter(b, a.dataType)), i = f, f = k.shift()) if ("*" === f) f = i; else if ("*" !== i && i !== f) {
                if (g = j[i + " " + f] || j["* " + f], !g) for (e in j) if (h = e.split(" "), h[1] === f && (g = j[i + " " + h[0]] || j["* " + h[0]])) {
                    g === !0 ? g = j[e] : j[e] !== !0 && (f = h[0], k.unshift(h[1]));
                    break
                }
                if (g !== !0) if (g && a["throws"]) b = g(b); else try {
                    b = g(b)
                } catch (l) {
                    return {state: "parsererror", error: g ? l : "No conversion from " + i + " to " + f}
                }
            }
            return {state: "success", data: b}
        }

        r.extend({
            active: 0, lastModified: {}, etag: {}, ajaxSettings: {
                url: tb.href, type: "GET", isLocal: Fb.test(tb.protocol), global: !0, processData: !0, async: !0,
                contentType: "application/x-www-form-urlencoded; charset=UTF-8", accepts: {
                    "*": Kb, text: "text/plain", html: "text/html", xml: "application/xml, text/xml",
                    json: "application/json, text/javascript"
                }, contents: {xml: /\bxml\b/, html: /\bhtml/, json: /\bjson\b/},
                responseFields: {xml: "responseXML", text: "responseText", json: "responseJSON"},
                converters: {"* text": String, "text html": !0, "text json": JSON.parse, "text xml": r.parseXML},
                flatOptions: {url: !0, context: !0}
            }, ajaxSetup: function (a, b) {
                return b ? Ob(Ob(a, r.ajaxSettings), b) : Ob(r.ajaxSettings, a)
            }, ajaxPrefilter: Mb(Ib), ajaxTransport: Mb(Jb), ajax: function (b, c) {
                "object" == typeof b && (c = b, b = void 0), c = c || {};
                var e, f, g, h, i, j, k, l, m, n, o = r.ajaxSetup({}, c), p = o.context || o,
                  q = o.context && (p.nodeType || p.jquery) ? r(p) : r.event, s = r.Deferred(),
                  t = r.Callbacks("once memory"), u = o.statusCode || {}, v = {}, w = {}, x = "canceled", y = {
                      readyState: 0, getResponseHeader: function (a) {
                          var b;
                          if (k) {
                              if (!h) {
                                  h = {};
                                  while (b = Eb.exec(g)) h[b[1].toLowerCase()] = b[2]
                              }
                              b = h[a.toLowerCase()]
                          }
                          return null == b ? null : b
                      }, getAllResponseHeaders: function () {
                          return k ? g : null
                      }, setRequestHeader: function (a, b) {
                          return null == k && (a = w[a.toLowerCase()] = w[a.toLowerCase()] || a, v[a] = b), this
                      }, overrideMimeType: function (a) {
                          return null == k && (o.mimeType = a), this
                      }, statusCode: function (a) {
                          var b;
                          if (a) if (k) y.always(a[y.status]); else for (b in a) u[b] = [u[b], a[b]];
                          return this
                      }, abort: function (a) {
                          var b = a || x;
                          return e && e.abort(b), A(0, b), this
                      }
                  };
                if (s.promise(y), o.url = ((b || o.url || tb.href) + "").replace(Hb, tb.protocol + "//"), o.type = c.method || c.type || o.method || o.type, o.dataTypes = (o.dataType || "*").toLowerCase().match(L) || [""], null == o.crossDomain) {
                    j = d.createElement("a");
                    try {
                        j.href = o.url, j.href = j.href, o.crossDomain = Lb.protocol + "//" + Lb.host != j.protocol + "//" + j.host
                    } catch (z) {
                        o.crossDomain = !0
                    }
                }
                if (o.data && o.processData && "string" != typeof o.data && (o.data = r.param(o.data, o.traditional)), Nb(Ib, o, c, y), k) return y;
                l = r.event && o.global, l && 0 === r.active++ && r.event.trigger("ajaxStart"), o.type = o.type.toUpperCase(), o.hasContent = !Gb.test(o.type), f = o.url.replace(Cb, ""), o.hasContent ? o.data && o.processData && 0 === (o.contentType || "").indexOf("application/x-www-form-urlencoded") && (o.data = o.data.replace(Bb, "+")) : (n = o.url.slice(f.length), o.data && (f += (vb.test(f) ? "&" : "?") + o.data, delete o.data), o.cache === !1 && (f = f.replace(Db, "$1"), n = (vb.test(f) ? "&" : "?") + "_=" + ub++ + n), o.url = f + n), o.ifModified && (r.lastModified[f] && y.setRequestHeader("If-Modified-Since", r.lastModified[f]), r.etag[f] && y.setRequestHeader("If-None-Match", r.etag[f])), (o.data && o.hasContent && o.contentType !== !1 || c.contentType) && y.setRequestHeader("Content-Type", o.contentType), y.setRequestHeader("Accept", o.dataTypes[0] && o.accepts[o.dataTypes[0]] ? o.accepts[o.dataTypes[0]] + ("*" !== o.dataTypes[0] ? ", " + Kb + "; q=0.01" : "") : o.accepts["*"]);
                for (m in o.headers) y.setRequestHeader(m, o.headers[m]);
                if (o.beforeSend && (o.beforeSend.call(p, y, o) === !1 || k)) return y.abort();
                if (x = "abort", t.add(o.complete), y.done(o.success), y.fail(o.error), e = Nb(Jb, o, c, y)) {
                    if (y.readyState = 1, l && q.trigger("ajaxSend", [y, o]), k) return y;
                    o.async && o.timeout > 0 && (i = a.setTimeout(function () {
                        y.abort("timeout")
                    }, o.timeout));
                    try {
                        k = !1, e.send(v, A)
                    } catch (z) {
                        if (k) throw z;
                        A(-1, z)
                    }
                } else A(-1, "No Transport");

                function A(b, c, d, h) {
                    var j, m, n, v, w, x = c;
                    k || (k = !0, i && a.clearTimeout(i), e = void 0, g = h || "", y.readyState = b > 0 ? 4 : 0, j = b >= 200 && b < 300 || 304 === b, d && (v = Pb(o, y, d)), v = Qb(o, v, y, j), j ? (o.ifModified && (w = y.getResponseHeader("Last-Modified"), w && (r.lastModified[f] = w), w = y.getResponseHeader("etag"), w && (r.etag[f] = w)), 204 === b || "HEAD" === o.type ? x = "nocontent" : 304 === b ? x = "notmodified" : (x = v.state, m = v.data, n = v.error, j = !n)) : (n = x, !b && x || (x = "error", b < 0 && (b = 0))), y.status = b, y.statusText = (c || x) + "", j ? s.resolveWith(p, [m, x, y]) : s.rejectWith(p, [y, x, n]), y.statusCode(u), u = void 0, l && q.trigger(j ? "ajaxSuccess" : "ajaxError", [y, o, j ? m : n]), t.fireWith(p, [y, x]), l && (q.trigger("ajaxComplete", [y, o]), --r.active || r.event.trigger("ajaxStop")))
                }

                return y
            }, getJSON: function (a, b, c) {
                return r.get(a, b, c, "json")
            }, getScript: function (a, b) {
                return r.get(a, void 0, b, "script")
            }
        }), r.each(["get", "post"], function (a, b) {
            r[b] = function (a, c, d, e) {
                return r.isFunction(c) && (e = e || d, d = c, c = void 0), r.ajax(r.extend({
                    url: a, type: b, dataType: e, data: c, success: d
                }, r.isPlainObject(a) && a))
            }
        }), r._evalUrl = function (a) {
            return r.ajax({url: a, type: "GET", dataType: "script", cache: !0, async: !1, global: !1, "throws": !0})
        }, r.fn.extend({
            wrapAll: function (a) {
                var b;
                return this[0] && (r.isFunction(a) && (a = a.call(this[0])), b = r(a, this[0].ownerDocument).eq(0).clone(!0), this[0].parentNode && b.insertBefore(this[0]), b.map(function () {
                    var a = this;
                    while (a.firstElementChild) a = a.firstElementChild;
                    return a
                }).append(this)), this
            }, wrapInner: function (a) {
                return r.isFunction(a) ? this.each(function (b) {
                    r(this).wrapInner(a.call(this, b))
                }) : this.each(function () {
                    var b = r(this), c = b.contents();
                    c.length ? c.wrapAll(a) : b.append(a)
                })
            }, wrap: function (a) {
                var b = r.isFunction(a);
                return this.each(function (c) {
                    r(this).wrapAll(b ? a.call(this, c) : a)
                })
            }, unwrap: function (a) {
                return this.parent(a).not("body").each(function () {
                    r(this).replaceWith(this.childNodes)
                }), this
            }
        }), r.expr.pseudos.hidden = function (a) {
            return !r.expr.pseudos.visible(a)
        }, r.expr.pseudos.visible = function (a) {
            return !!(a.offsetWidth || a.offsetHeight || a.getClientRects().length)
        }, r.ajaxSettings.xhr = function () {
            try {
                return new a.XMLHttpRequest
            } catch (b) {
            }
        };
        var Rb = {0: 200, 1223: 204}, Sb = r.ajaxSettings.xhr();
        o.cors = !!Sb && "withCredentials" in Sb, o.ajax = Sb = !!Sb, r.ajaxTransport(function (b) {
            var c, d;
            if (o.cors || Sb && !b.crossDomain) return {
                send: function (e, f) {
                    var g, h = b.xhr();
                    if (h.open(b.type, b.url, b.async, b.username, b.password), b.xhrFields) for (g in b.xhrFields) h[g] = b.xhrFields[g];
                    b.mimeType && h.overrideMimeType && h.overrideMimeType(b.mimeType), b.crossDomain || e["X-Requested-With"] || (e["X-Requested-With"] = "XMLHttpRequest");
                    for (g in e) h.setRequestHeader(g, e[g]);
                    c = function (a) {
                        return function () {
                            c && (c = d = h.onload = h.onerror = h.onabort = h.onreadystatechange = null, "abort" === a ? h.abort() : "error" === a ? "number" != typeof h.status ? f(0, "error") : f(h.status, h.statusText) : f(Rb[h.status] || h.status, h.statusText, "text" !== (h.responseType || "text") || "string" != typeof h.responseText ? {binary: h.response} : {text: h.responseText}, h.getAllResponseHeaders()))
                        }
                    }, h.onload = c(), d = h.onerror = c("error"), void 0 !== h.onabort ? h.onabort = d : h.onreadystatechange = function () {
                        4 === h.readyState && a.setTimeout(function () {
                            c && d()
                        })
                    }, c = c("abort");
                    try {
                        h.send(b.hasContent && b.data || null)
                    } catch (i) {
                        if (c) throw i
                    }
                }, abort: function () {
                    c && c()
                }
            }
        }), r.ajaxPrefilter(function (a) {
            a.crossDomain && (a.contents.script = !1)
        }), r.ajaxSetup({
            accepts: {script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},
            contents: {script: /\b(?:java|ecma)script\b/}, converters: {
                "text script": function (a) {
                    return r.globalEval(a), a
                }
            }
        }), r.ajaxPrefilter("script", function (a) {
            void 0 === a.cache && (a.cache = !1), a.crossDomain && (a.type = "GET")
        }), r.ajaxTransport("script", function (a) {
            if (a.crossDomain) {
                var b, c;
                return {
                    send: function (e, f) {
                        b = r("<script>").prop({
                            charset: a.scriptCharset, src: a.url
                        }).on("load error", c = function (a) {
                            b.remove(), c = null, a && f("error" === a.type ? 404 : 200, a.type)
                        }), d.head.appendChild(b[0])
                    }, abort: function () {
                        c && c()
                    }
                }
            }
        });
        var Tb = [], Ub = /(=)\?(?=&|$)|\?\?/;
        r.ajaxSetup({
            jsonp: "callback", jsonpCallback: function () {
                var a = Tb.pop() || r.expando + "_" + ub++;
                return this[a] = !0, a
            }
        }), r.ajaxPrefilter("json jsonp", function (b, c, d) {
            var e, f, g,
              h = b.jsonp !== !1 && (Ub.test(b.url) ? "url" : "string" == typeof b.data && 0 === (b.contentType || "").indexOf("application/x-www-form-urlencoded") && Ub.test(b.data) && "data");
            if (h || "jsonp" === b.dataTypes[0]) return e = b.jsonpCallback = r.isFunction(b.jsonpCallback) ? b.jsonpCallback() : b.jsonpCallback, h ? b[h] = b[h].replace(Ub, "$1" + e) : b.jsonp !== !1 && (b.url += (vb.test(b.url) ? "&" : "?") + b.jsonp + "=" + e), b.converters["script json"] = function () {
                return g || r.error(e + " was not called"), g[0]
            }, b.dataTypes[0] = "json", f = a[e], a[e] = function () {
                g = arguments
            }, d.always(function () {
                void 0 === f ? r(a).removeProp(e) : a[e] = f, b[e] && (b.jsonpCallback = c.jsonpCallback, Tb.push(e)), g && r.isFunction(f) && f(g[0]), g = f = void 0
            }), "script"
        }), o.createHTMLDocument = function () {
            var a = d.implementation.createHTMLDocument("").body;
            return a.innerHTML = "<form></form><form></form>", 2 === a.childNodes.length
        }(), r.parseHTML = function (a, b, c) {
            if ("string" != typeof a) return [];
            "boolean" == typeof b && (c = b, b = !1);
            var e, f, g;
            return b || (o.createHTMLDocument ? (b = d.implementation.createHTMLDocument(""), e = b.createElement("base"), e.href = d.location.href, b.head.appendChild(e)) : b = d), f = C.exec(a), g = !c && [], f ? [b.createElement(f[1])] : (f = qa([a], b, g), g && g.length && r(g).remove(), r.merge([], f.childNodes))
        }, r.fn.load = function (a, b, c) {
            var d, e, f, g = this, h = a.indexOf(" ");
            return h > -1 && (d = pb(a.slice(h)), a = a.slice(0, h)), r.isFunction(b) ? (c = b, b = void 0) : b && "object" == typeof b && (e = "POST"), g.length > 0 && r.ajax({
                url: a, type: e || "GET", dataType: "html", data: b
            }).done(function (a) {
                f = arguments, g.html(d ? r("<div>").append(r.parseHTML(a)).find(d) : a)
            }).always(c && function (a, b) {
                g.each(function () {
                    c.apply(this, f || [a.responseText, b, a])
                })
            }), this
        }, r.each(["ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend"], function (a, b) {
            r.fn[b] = function (a) {
                return this.on(b, a)
            }
        }), r.expr.pseudos.animated = function (a) {
            return r.grep(r.timers, function (b) {
                return a === b.elem
            }).length
        }, r.offset = {
            setOffset: function (a, b, c) {
                var d, e, f, g, h, i, j, k = r.css(a, "position"), l = r(a), m = {};
                "static" === k && (a.style.position = "relative"), h = l.offset(), f = r.css(a, "top"), i = r.css(a, "left"), j = ("absolute" === k || "fixed" === k) && (f + i).indexOf("auto") > -1, j ? (d = l.position(), g = d.top, e = d.left) : (g = parseFloat(f) || 0, e = parseFloat(i) || 0), r.isFunction(b) && (b = b.call(a, c, r.extend({}, h))), null != b.top && (m.top = b.top - h.top + g), null != b.left && (m.left = b.left - h.left + e), "using" in b ? b.using.call(a, m) : l.css(m)
            }
        }, r.fn.extend({
            offset: function (a) {
                if (arguments.length) return void 0 === a ? this : this.each(function (b) {
                    r.offset.setOffset(this, a, b)
                });
                var b, c, d, e, f = this[0];
                if (f) return f.getClientRects().length ? (d = f.getBoundingClientRect(), b = f.ownerDocument, c = b.documentElement, e = b.defaultView, {
                    top: d.top + e.pageYOffset - c.clientTop, left: d.left + e.pageXOffset - c.clientLeft
                }) : {top: 0, left: 0}
            }, position: function () {
                if (this[0]) {
                    var a, b, c = this[0], d = {top: 0, left: 0};
                    return "fixed" === r.css(c, "position") ? b = c.getBoundingClientRect() : (a = this.offsetParent(), b = this.offset(), B(a[0], "html") || (d = a.offset()), d = {
                        top: d.top + r.css(a[0], "borderTopWidth", !0),
                        left: d.left + r.css(a[0], "borderLeftWidth", !0)
                    }), {
                        top: b.top - d.top - r.css(c, "marginTop", !0),
                        left: b.left - d.left - r.css(c, "marginLeft", !0)
                    }
                }
            }, offsetParent: function () {
                return this.map(function () {
                    var a = this.offsetParent;
                    while (a && "static" === r.css(a, "position")) a = a.offsetParent;
                    return a || ra
                })
            }
        }), r.each({scrollLeft: "pageXOffset", scrollTop: "pageYOffset"}, function (a, b) {
            var c = "pageYOffset" === b;
            r.fn[a] = function (d) {
                return T(this, function (a, d, e) {
                    var f;
                    return r.isWindow(a) ? f = a : 9 === a.nodeType && (f = a.defaultView), void 0 === e ? f ? f[b] : a[d] : void (f ? f.scrollTo(c ? f.pageXOffset : e, c ? e : f.pageYOffset) : a[d] = e)
                }, a, d, arguments.length)
            }
        }), r.each(["top", "left"], function (a, b) {
            r.cssHooks[b] = Pa(o.pixelPosition, function (a, c) {
                if (c) return c = Oa(a, b), Ma.test(c) ? r(a).position()[b] + "px" : c
            })
        }), r.each({Height: "height", Width: "width"}, function (a, b) {
            r.each({padding: "inner" + a, content: b, "": "outer" + a}, function (c, d) {
                r.fn[d] = function (e, f) {
                    var g = arguments.length && (c || "boolean" != typeof e),
                      h = c || (e === !0 || f === !0 ? "margin" : "border");
                    return T(this, function (b, c, e) {
                        var f;
                        return r.isWindow(b) ? 0 === d.indexOf("outer") ? b["inner" + a] : b.document.documentElement["client" + a] : 9 === b.nodeType ? (f = b.documentElement, Math.max(b.body["scroll" + a], f["scroll" + a], b.body["offset" + a], f["offset" + a], f["client" + a])) : void 0 === e ? r.css(b, c, h) : r.style(b, c, e, h)
                    }, b, g ? e : void 0, g)
                }
            })
        }), r.fn.extend({
            bind: function (a, b, c) {
                return this.on(a, null, b, c)
            }, unbind: function (a, b) {
                return this.off(a, null, b)
            }, delegate: function (a, b, c, d) {
                return this.on(b, a, c, d)
            }, undelegate: function (a, b, c) {
                return 1 === arguments.length ? this.off(a, "**") : this.off(b, a || "**", c)
            }
        }), r.holdReady = function (a) {
            a ? r.readyWait++ : r.ready(!0)
        }, r.isArray = Array.isArray, r.parseJSON = JSON.parse, r.nodeName = B, "function" == typeof define && define.amd && define("jquery", [], function () {
            return r
        });
        var Vb = a.jQuery, Wb = a.$;
        return r.noConflict = function (b) {
            return a.$ === r && (a.$ = Wb), b && a.jQuery === r && (a.jQuery = Vb), r
        }, b || (a.jQuery = a.$ = r), r
    });
</script>
<style>
    /** layui-v2.2.45 MIT License By http://www.layui.com */
    .layui-inline, img {
        display: inline-block;
        vertical-align: middle
    }

    h1, h2, h3, h4, h5, h6 {
        font-weight: 400
    }

    .layui-edge, .layui-header, .layui-inline, .layui-main {
        position: relative
    }

    .layui-btn, .layui-edge, .layui-inline, img {
        vertical-align: middle
    }

    blockquote, body, button, dd, div, dl, dt, form, h1, h2, h3, h4, h5, h6, input, li, ol, p, pre, td, textarea, th, ul {
        margin: 0;
        padding: 0;
        -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
    }

    a:active, a:hover {
        outline: 0
    }

    img {
        border: none
    }

    li {
        list-style: none
    }

    table {
        border-collapse: collapse;
        border-spacing: 0
    }

    h4, h5, h6 {
        font-size: 100%
    }

    button, input, optgroup, option, select, textarea {
        font-family: inherit;
        font-size: inherit;
        font-style: inherit;
        font-weight: inherit;
        outline: 0
    }

    pre {
        white-space: pre-wrap;
        white-space: -moz-pre-wrap;
        white-space: -pre-wrap;
        white-space: -o-pre-wrap;
        word-wrap: break-word
    }

    body {
        line-height: 24px;
        font: 14px Helvetica Neue, Helvetica, PingFang SC, \5FAE\8F6F\96C5\9ED1, Tahoma, Arial, sans-serif
    }

    hr {
        height: 1px;
        margin: 10px 0;
        border: 0;
        clear: both
    }

    a {
        color: #333;
        text-decoration: none
    }

    a:hover {
        color: #777
    }

    a cite {
        font-style: normal;
        *cursor: pointer
    }

    .layui-border-box, .layui-border-box * {
        box-sizing: border-box
    }

    .layui-box, .layui-box * {
        box-sizing: content-box
    }

    .layui-clear {
        clear: both;
        *zoom: 1
    }

    .layui-clear:after {
        content: '\20';
        clear: both;
        *zoom: 1;
        display: block;
        height: 0
    }

    .layui-inline {
        *display: inline;
        *zoom: 1
    }

    .layui-edge {
        display: inline-block;
        width: 0;
        height: 0;
        border-width: 6px;
        border-style: dashed;
        border-color: transparent;
        overflow: hidden
    }

    .layui-edge-top {
        top: -4px;
        border-bottom-color: #999;
        border-bottom-style: solid
    }

    .layui-edge-right {
        border-left-color: #999;
        border-left-style: solid
    }

    .layui-edge-bottom {
        top: 2px;
        border-top-color: #999;
        border-top-style: solid
    }

    .layui-edge-left {
        border-right-color: #999;
        border-right-style: solid
    }

    .layui-elip {
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap
    }

    .layui-disabled, .layui-icon, .layui-unselect {
        -moz-user-select: none;
        -webkit-user-select: none;
        -ms-user-select: none
    }

    .layui-disabled, .layui-disabled:hover {
        color: #d2d2d2 !important;
        cursor: not-allowed !important
    }

    .layui-circle {
        border-radius: 100%
    }

    .layui-show {
        display: block !important
    }

    .layui-hide {
        display: none !important
    }

    @font-face {
        font-family: layui-icon;
        src: url(../font/iconfont.eot?v=220);
        src: url(../font/iconfont.eot?v=220#iefix) format('embedded-opentype'), url(../font/iconfont.svg?v=220#iconfont) format('svg'), url(../font/iconfont.woff?v=220) format('woff'), url(../font/iconfont.ttf?v=220) format('truetype')
    }

    .layui-icon {
        font-family: layui-icon !important;
        font-size: 16px;
        font-style: normal;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale
    }

    .layui-main {
        width: 1140px;
        margin: 0 auto
    }

    .layui-header {
        z-index: 1000;
        height: 60px
    }

    .layui-header a:hover {
        transition: all .5s;
        -webkit-transition: all .5s
    }

    .layui-side {
        position: fixed;
        top: 0;
        bottom: 0;
        z-index: 999;
        width: 200px;
        overflow-x: hidden
    }

    .layui-side-scroll {
        width: 220px;
        height: 100%;
        overflow-x: hidden
    }

    .layui-body {
        position: absolute;
        left: 200px;
        right: 0;
        top: 0;
        bottom: 0;
        z-index: 998;
        width: auto;
        overflow: hidden;
        overflow-y: auto;
        box-sizing: border-box
    }

    .layui-layout-body {
        overflow: hidden
    }

    .layui-layout-admin .layui-header {
        background-color: #23262E
    }

    .layui-layout-admin .layui-side {
        top: 60px;
        width: 200px;
        overflow-x: hidden
    }

    .layui-layout-admin .layui-body {
        top: 60px;
        bottom: 44px
    }

    .layui-layout-admin .layui-main {
        width: auto;
        margin: 0 15px
    }

    .layui-layout-admin .layui-footer {
        position: fixed;
        left: 200px;
        right: 0;
        bottom: 0;
        height: 44px;
        line-height: 44px;
        padding: 0 15px;
        background-color: #eee
    }

    .layui-layout-admin .layui-logo {
        position: absolute;
        left: 0;
        top: 0;
        width: 200px;
        height: 100%;
        line-height: 60px;
        text-align: center;
        color: #009688;
        font-size: 16px
    }

    .layui-layout-admin .layui-header .layui-nav {
        background: 0 0
    }

    .layui-layout-left {
        position: absolute !important;
        left: 200px;
        top: 0
    }

    .layui-layout-right {
        position: absolute !important;
        right: 0;
        top: 0
    }

    .layui-container {
        position: relative;
        margin: 0 auto;
        padding: 0 15px;
        box-sizing: border-box
    }

    .layui-fluid {
        position: relative;
        margin: 0 auto;
        padding: 0 15px
    }

    .layui-row:after, .layui-row:before {
        content: '';
        display: block;
        clear: both
    }

    .layui-col-lg1, .layui-col-lg10, .layui-col-lg11, .layui-col-lg12, .layui-col-lg2, .layui-col-lg3, .layui-col-lg4, .layui-col-lg5, .layui-col-lg6, .layui-col-lg7, .layui-col-lg8, .layui-col-lg9, .layui-col-md1, .layui-col-md10, .layui-col-md11, .layui-col-md12, .layui-col-md2, .layui-col-md3, .layui-col-md4, .layui-col-md5, .layui-col-md6, .layui-col-md7, .layui-col-md8, .layui-col-md9, .layui-col-sm1, .layui-col-sm10, .layui-col-sm11, .layui-col-sm12, .layui-col-sm2, .layui-col-sm3, .layui-col-sm4, .layui-col-sm5, .layui-col-sm6, .layui-col-sm7, .layui-col-sm8, .layui-col-sm9, .layui-col-xs1, .layui-col-xs10, .layui-col-xs11, .layui-col-xs12, .layui-col-xs2, .layui-col-xs3, .layui-col-xs4, .layui-col-xs5, .layui-col-xs6, .layui-col-xs7, .layui-col-xs8, .layui-col-xs9 {
        position: relative;
        display: block;
        box-sizing: border-box
    }

    .layui-col-xs1, .layui-col-xs10, .layui-col-xs11, .layui-col-xs12, .layui-col-xs2, .layui-col-xs3, .layui-col-xs4, .layui-col-xs5, .layui-col-xs6, .layui-col-xs7, .layui-col-xs8, .layui-col-xs9 {
        float: left
    }

    .layui-col-xs1 {
        width: 8.33333333%
    }

    .layui-col-xs2 {
        width: 16.66666667%
    }

    .layui-col-xs3 {
        width: 25%
    }

    .layui-col-xs4 {
        width: 33.33333333%
    }

    .layui-col-xs5 {
        width: 41.66666667%
    }

    .layui-col-xs6 {
        width: 50%
    }

    .layui-col-xs7 {
        width: 58.33333333%
    }

    .layui-col-xs8 {
        width: 66.66666667%
    }

    .layui-col-xs9 {
        width: 75%
    }

    .layui-col-xs10 {
        width: 83.33333333%
    }

    .layui-col-xs11 {
        width: 91.66666667%
    }

    .layui-col-xs12 {
        width: 100%
    }

    .layui-col-xs-offset1 {
        margin-left: 8.33333333%
    }

    .layui-col-xs-offset2 {
        margin-left: 16.66666667%
    }

    .layui-col-xs-offset3 {
        margin-left: 25%
    }

    .layui-col-xs-offset4 {
        margin-left: 33.33333333%
    }

    .layui-col-xs-offset5 {
        margin-left: 41.66666667%
    }

    .layui-col-xs-offset6 {
        margin-left: 50%
    }

    .layui-col-xs-offset7 {
        margin-left: 58.33333333%
    }

    .layui-col-xs-offset8 {
        margin-left: 66.66666667%
    }

    .layui-col-xs-offset9 {
        margin-left: 75%
    }

    .layui-col-xs-offset10 {
        margin-left: 83.33333333%
    }

    .layui-col-xs-offset11 {
        margin-left: 91.66666667%
    }

    .layui-col-xs-offset12 {
        margin-left: 100%
    }

    @media screen and (max-width: 768px) {
        .layui-hide-xs {
            display: none !important
        }

        .layui-show-xs-block {
            display: block !important
        }

        .layui-show-xs-inline {
            display: inline !important
        }

        .layui-show-xs-inline-block {
            display: inline-block !important
        }
    }

    @media screen and (min-width: 768px) {
        .layui-container {
            width: 750px
        }

        .layui-hide-sm {
            display: none !important
        }

        .layui-show-sm-block {
            display: block !important
        }

        .layui-show-sm-inline {
            display: inline !important
        }

        .layui-show-sm-inline-block {
            display: inline-block !important
        }

        .layui-col-sm1, .layui-col-sm10, .layui-col-sm11, .layui-col-sm12, .layui-col-sm2, .layui-col-sm3, .layui-col-sm4, .layui-col-sm5, .layui-col-sm6, .layui-col-sm7, .layui-col-sm8, .layui-col-sm9 {
            float: left
        }

        .layui-col-sm1 {
            width: 8.33333333%
        }

        .layui-col-sm2 {
            width: 16.66666667%
        }

        .layui-col-sm3 {
            width: 25%
        }

        .layui-col-sm4 {
            width: 33.33333333%
        }

        .layui-col-sm5 {
            width: 41.66666667%
        }

        .layui-col-sm6 {
            width: 50%
        }

        .layui-col-sm7 {
            width: 58.33333333%
        }

        .layui-col-sm8 {
            width: 66.66666667%
        }

        .layui-col-sm9 {
            width: 75%
        }

        .layui-col-sm10 {
            width: 83.33333333%
        }

        .layui-col-sm11 {
            width: 91.66666667%
        }

        .layui-col-sm12 {
            width: 100%
        }

        .layui-col-sm-offset1 {
            margin-left: 8.33333333%
        }

        .layui-col-sm-offset2 {
            margin-left: 16.66666667%
        }

        .layui-col-sm-offset3 {
            margin-left: 25%
        }

        .layui-col-sm-offset4 {
            margin-left: 33.33333333%
        }

        .layui-col-sm-offset5 {
            margin-left: 41.66666667%
        }

        .layui-col-sm-offset6 {
            margin-left: 50%
        }

        .layui-col-sm-offset7 {
            margin-left: 58.33333333%
        }

        .layui-col-sm-offset8 {
            margin-left: 66.66666667%
        }

        .layui-col-sm-offset9 {
            margin-left: 75%
        }

        .layui-col-sm-offset10 {
            margin-left: 83.33333333%
        }

        .layui-col-sm-offset11 {
            margin-left: 91.66666667%
        }

        .layui-col-sm-offset12 {
            margin-left: 100%
        }
    }

    @media screen and (min-width: 992px) {
        .layui-container {
            width: 970px
        }

        .layui-hide-md {
            display: none !important
        }

        .layui-show-md-block {
            display: block !important
        }

        .layui-show-md-inline {
            display: inline !important
        }

        .layui-show-md-inline-block {
            display: inline-block !important
        }

        .layui-col-md1, .layui-col-md10, .layui-col-md11, .layui-col-md12, .layui-col-md2, .layui-col-md3, .layui-col-md4, .layui-col-md5, .layui-col-md6, .layui-col-md7, .layui-col-md8, .layui-col-md9 {
            float: left
        }

        .layui-col-md1 {
            width: 8.33333333%
        }

        .layui-col-md2 {
            width: 16.66666667%
        }

        .layui-col-md3 {
            width: 25%
        }

        .layui-col-md4 {
            width: 33.33333333%
        }

        .layui-col-md5 {
            width: 41.66666667%
        }

        .layui-col-md6 {
            width: 50%
        }

        .layui-col-md7 {
            width: 58.33333333%
        }

        .layui-col-md8 {
            width: 66.66666667%
        }

        .layui-col-md9 {
            width: 75%
        }

        .layui-col-md10 {
            width: 83.33333333%
        }

        .layui-col-md11 {
            width: 91.66666667%
        }

        .layui-col-md12 {
            width: 100%
        }

        .layui-col-md-offset1 {
            margin-left: 8.33333333%
        }

        .layui-col-md-offset2 {
            margin-left: 16.66666667%
        }

        .layui-col-md-offset3 {
            margin-left: 25%
        }

        .layui-col-md-offset4 {
            margin-left: 33.33333333%
        }

        .layui-col-md-offset5 {
            margin-left: 41.66666667%
        }

        .layui-col-md-offset6 {
            margin-left: 50%
        }

        .layui-col-md-offset7 {
            margin-left: 58.33333333%
        }

        .layui-col-md-offset8 {
            margin-left: 66.66666667%
        }

        .layui-col-md-offset9 {
            margin-left: 75%
        }

        .layui-col-md-offset10 {
            margin-left: 83.33333333%
        }

        .layui-col-md-offset11 {
            margin-left: 91.66666667%
        }

        .layui-col-md-offset12 {
            margin-left: 100%
        }
    }

    @media screen and (min-width: 1200px) {
        .layui-container {
            width: 1170px
        }

        .layui-hide-lg {
            display: none !important
        }

        .layui-show-lg-block {
            display: block !important
        }

        .layui-show-lg-inline {
            display: inline !important
        }

        .layui-show-lg-inline-block {
            display: inline-block !important
        }

        .layui-col-lg1, .layui-col-lg10, .layui-col-lg11, .layui-col-lg12, .layui-col-lg2, .layui-col-lg3, .layui-col-lg4, .layui-col-lg5, .layui-col-lg6, .layui-col-lg7, .layui-col-lg8, .layui-col-lg9 {
            float: left
        }

        .layui-col-lg1 {
            width: 8.33333333%
        }

        .layui-col-lg2 {
            width: 16.66666667%
        }

        .layui-col-lg3 {
            width: 25%
        }

        .layui-col-lg4 {
            width: 33.33333333%
        }

        .layui-col-lg5 {
            width: 41.66666667%
        }

        .layui-col-lg6 {
            width: 50%
        }

        .layui-col-lg7 {
            width: 58.33333333%
        }

        .layui-col-lg8 {
            width: 66.66666667%
        }

        .layui-col-lg9 {
            width: 75%
        }

        .layui-col-lg10 {
            width: 83.33333333%
        }

        .layui-col-lg11 {
            width: 91.66666667%
        }

        .layui-col-lg12 {
            width: 100%
        }

        .layui-col-lg-offset1 {
            margin-left: 8.33333333%
        }

        .layui-col-lg-offset2 {
            margin-left: 16.66666667%
        }

        .layui-col-lg-offset3 {
            margin-left: 25%
        }

        .layui-col-lg-offset4 {
            margin-left: 33.33333333%
        }

        .layui-col-lg-offset5 {
            margin-left: 41.66666667%
        }

        .layui-col-lg-offset6 {
            margin-left: 50%
        }

        .layui-col-lg-offset7 {
            margin-left: 58.33333333%
        }

        .layui-col-lg-offset8 {
            margin-left: 66.66666667%
        }

        .layui-col-lg-offset9 {
            margin-left: 75%
        }

        .layui-col-lg-offset10 {
            margin-left: 83.33333333%
        }

        .layui-col-lg-offset11 {
            margin-left: 91.66666667%
        }

        .layui-col-lg-offset12 {
            margin-left: 100%
        }
    }

    .layui-col-space1 {
        margin: -.5px
    }

    .layui-col-space1 > * {
        padding: .5px
    }

    .layui-col-space3 {
        margin: -1.5px
    }

    .layui-col-space3 > * {
        padding: 1.5px
    }

    .layui-col-space5 {
        margin: -2.5px
    }

    .layui-col-space5 > * {
        padding: 2.5px
    }

    .layui-col-space8 {
        margin: -3.5px
    }

    .layui-col-space8 > * {
        padding: 3.5px
    }

    .layui-col-space10 {
        margin: -5px
    }

    .layui-col-space10 > * {
        padding: 5px
    }

    .layui-col-space12 {
        margin: -6px
    }

    .layui-col-space12 > * {
        padding: 6px
    }

    .layui-col-space15 {
        margin: -7.5px
    }

    .layui-col-space15 > * {
        padding: 7.5px
    }

    .layui-col-space18 {
        margin: -9px
    }

    .layui-col-space18 > * {
        padding: 9px
    }

    .layui-col-space20 {
        margin: -10px
    }

    .layui-col-space20 > * {
        padding: 10px
    }

    .layui-col-space22 {
        margin: -11px
    }

    .layui-col-space22 > * {
        padding: 11px
    }

    .layui-col-space25 {
        margin: -12.5px
    }

    .layui-col-space25 > * {
        padding: 12.5px
    }

    .layui-col-space30 {
        margin: -15px
    }

    .layui-col-space30 > * {
        padding: 15px
    }

    .layui-btn, .layui-input, .layui-select, .layui-textarea, .layui-upload-button {
        outline: 0;
        -webkit-appearance: none;
        transition: all .3s;
        -webkit-transition: all .3s;
        box-sizing: border-box
    }

    .layui-elem-quote {
        margin-bottom: 10px;
        padding: 15px;
        line-height: 22px;
        border-left: 5px solid #009688;
        border-radius: 0 2px 2px 0;
        background-color: #f2f2f2
    }

    .layui-quote-nm {
        border-style: solid;
        border-width: 1px 1px 1px 5px;
        background: 0 0
    }

    .layui-elem-field {
        margin-bottom: 10px;
        padding: 0;
        border-width: 1px;
        border-style: solid
    }

    .layui-elem-field legend {
        margin-left: 20px;
        padding: 0 10px;
        font-size: 20px;
        font-weight: 300
    }

    .layui-field-title {
        margin: 10px 0 20px;
        border-width: 1px 0 0
    }

    .layui-field-box {
        padding: 10px 15px
    }

    .layui-field-title .layui-field-box {
        padding: 10px 0
    }

    .layui-progress {
        position: relative;
        height: 6px;
        border-radius: 20px;
        background-color: #e2e2e2
    }

    .layui-progress-bar {
        position: absolute;
        left: 0;
        top: 0;
        width: 0;
        max-width: 100%;
        height: 6px;
        border-radius: 20px;
        text-align: right;
        background-color: #5FB878;
        transition: all .3s;
        -webkit-transition: all .3s
    }

    .layui-progress-big, .layui-progress-big .layui-progress-bar {
        height: 18px;
        line-height: 18px
    }

    .layui-progress-text {
        position: relative;
        top: -18px;
        line-height: 18px;
        font-size: 12px;
        color: #666
    }

    .layui-progress-big .layui-progress-text {
        position: static;
        padding: 0 10px;
        color: #fff
    }

    .layui-card-header, .layui-colla-title {
        position: relative;
        height: 42px;
        color: #333;
        font-size: 14px
    }

    .layui-card {
        margin-bottom: 15px;
        border-radius: 2px;
        background-color: #fff;
        box-shadow: 0 1px 2px 0 rgba(0, 0, 0, .05)
    }

    .layui-card:last-child {
        margin-bottom: 0
    }

    .layui-card-header {
        line-height: 42px;
        padding: 0 15px;
        border-bottom: 1px solid #f6f6f6;
        border-radius: 2px 2px 0 0
    }

    .layui-card-body {
        position: relative;
        padding: 10px 15px;
        line-height: 24px
    }

    .layui-card-body .layui-table {
        margin: 5px 0
    }

    .layui-card .layui-tab {
        margin: 0
    }

    .layui-collapse {
        border-width: 1px;
        border-style: solid;
        border-radius: 2px
    }

    .layui-colla-content, .layui-colla-item {
        border-top-width: 1px;
        border-top-style: solid
    }

    .layui-colla-item:first-child {
        border-top: none
    }

    .layui-colla-title {
        line-height: 42px;
        padding: 0 15px 0 35px;
        background-color: #f2f2f2;
        cursor: pointer
    }

    .layui-colla-content {
        display: none;
        padding: 10px 15px;
        line-height: 22px;
        color: #666
    }

    .layui-bg-black, .layui-bg-blue, .layui-bg-cyan, .layui-bg-green, .layui-bg-orange, .layui-bg-red {
        color: #fff !important
    }

    .layui-colla-icon {
        position: absolute;
        left: 15px;
        top: 0;
        font-size: 14px
    }

    .layui-bg-red {
        background-color: #FF5722 !important
    }

    .layui-bg-orange {
        background-color: #FFB800 !important
    }

    .layui-bg-green {
        background-color: #009688 !important
    }

    .layui-bg-cyan {
        background-color: #2F4056 !important
    }

    .layui-bg-blue {
        background-color: #1E9FFF !important
    }

    .layui-bg-black {
        background-color: #393D49 !important
    }

    .layui-bg-gray {
        background-color: #eee !important;
        color: #666 !important
    }

    .layui-badge-rim, .layui-colla-content, .layui-colla-item, .layui-collapse, .layui-elem-field, .layui-form-pane .layui-form-item[pane], .layui-form-pane .layui-form-label, .layui-input, .layui-layedit, .layui-layedit-tool, .layui-quote-nm, .layui-select, .layui-tab-bar, .layui-tab-card, .layui-tab-title, .layui-tab-title .layui-this:after, .layui-textarea {
        border-color: #e6e6e6
    }

    .layui-timeline-item:before, hr {
        background-color: #e6e6e6
    }

    .layui-text {
        line-height: 22px;
        font-size: 14px;
        color: #666
    }

    .layui-text h1, .layui-text h2, .layui-text h3 {
        font-weight: 500;
        color: #333
    }

    .layui-text h1 {
        font-size: 30px
    }

    .layui-text h2 {
        font-size: 24px
    }

    .layui-text h3 {
        font-size: 18px
    }

    .layui-text a:not(.layui-btn) {
        color: #01AAED
    }

    .layui-text a:not(.layui-btn):hover {
        text-decoration: underline
    }

    .layui-text ul {
        padding: 5px 0 5px 15px
    }

    .layui-text ul li {
        margin-top: 5px;
        list-style-type: disc
    }

    .layui-text em, .layui-word-aux {
        color: #999 !important;
        padding: 0 5px !important
    }

    .layui-btn {
        display: inline-block;
        height: 38px;
        line-height: 38px;
        padding: 0 18px;
        background-color: #009688;
        color: #fff;
        white-space: nowrap;
        text-align: center;
        font-size: 14px;
        border: none;
        border-radius: 2px;
        cursor: pointer;
        -moz-user-select: none;
        -webkit-user-select: none;
        -ms-user-select: none
    }

    .layui-btn:hover {
        opacity: .8;
        filter: alpha(opacity=80);
        color: #fff
    }

    .layui-btn:active {
        opacity: 1;
        filter: alpha(opacity=100)
    }

    .layui-btn + .layui-btn {
        margin-left: 10px
    }

    .layui-btn-radius {
        border-radius: 100px
    }

    .layui-btn .layui-icon {
        margin-right: 3px;
        font-size: 18px;
        vertical-align: bottom;
        vertical-align: middle \9
    }

    .layui-btn-primary {
        border: 1px solid #C9C9C9;
        background-color: #fff;
        color: #555
    }

    .layui-btn-primary:hover {
        border-color: #009688;
        color: #333
    }

    .layui-btn-normal {
        background-color: #1E9FFF
    }

    .layui-btn-warm {
        background-color: #FFB800
    }

    .layui-btn-danger {
        background-color: #FF5722
    }

    .layui-btn-disabled, .layui-btn-disabled:active, .layui-btn-disabled:hover {
        border: 1px solid #e6e6e6;
        background-color: #FBFBFB;
        color: #C9C9C9;
        cursor: not-allowed;
        opacity: 1
    }

    .layui-btn-lg {
        height: 44px;
        line-height: 44px;
        padding: 0 25px;
        font-size: 16px
    }

    .layui-btn-sm {
        height: 30px;
        line-height: 30px;
        padding: 0 10px;
        font-size: 12px
    }

    .layui-btn-sm i {
        font-size: 16px !important
    }

    .layui-btn-xs {
        height: 22px;
        line-height: 22px;
        padding: 0 5px;
        font-size: 12px
    }

    .layui-btn-xs i {
        font-size: 14px !important
    }

    .layui-btn-group {
        display: inline-block;
        vertical-align: middle;
        font-size: 0
    }

    .layui-btn-group .layui-btn {
        margin-left: 0 !important;
        margin-right: 0 !important;
        border-left: 1px solid rgba(255, 255, 255, .5);
        border-radius: 0
    }

    .layui-btn-group .layui-btn-primary {
        border-left: none
    }

    .layui-btn-group .layui-btn-primary:hover {
        border-color: #C9C9C9;
        color: #009688
    }

    .layui-btn-group .layui-btn:first-child {
        border-left: none;
        border-radius: 2px 0 0 2px
    }

    .layui-btn-group .layui-btn-primary:first-child {
        border-left: 1px solid #c9c9c9
    }

    .layui-btn-group .layui-btn:last-child {
        border-radius: 0 2px 2px 0
    }

    .layui-btn-group .layui-btn + .layui-btn {
        margin-left: 0
    }

    .layui-btn-group + .layui-btn-group {
        margin-left: 10px
    }

    .layui-input, .layui-select, .layui-textarea {
        height: 38px;
        line-height: 1.3;
        line-height: 38px \9;
        border-width: 1px;
        border-style: solid;
        background-color: #fff;
        border-radius: 2px
    }

    .layui-input::-webkit-input-placeholder, .layui-select::-webkit-input-placeholder, .layui-textarea::-webkit-input-placeholder {
        line-height: 1.3
    }

    .layui-form-label, .layui-form-mid, .layui-textarea {
        line-height: 20px;
        position: relative
    }

    .layui-input, .layui-textarea {
        display: block;
        width: 100%;
        padding-left: 10px
    }

    .layui-input:hover, .layui-textarea:hover {
        border-color: #D2D2D2 !important
    }

    .layui-input:focus, .layui-textarea:focus {
        border-color: #C9C9C9 !important
    }

    .layui-textarea {
        min-height: 100px;
        height: auto;
        padding: 6px 10px;
        resize: vertical
    }

    .layui-select {
        padding: 0 10px
    }

    .layui-form input[type=checkbox], .layui-form input[type=radio], .layui-form select {
        display: none
    }

    .layui-form [lay-ignore] {
        display: initial
    }

    .layui-form-item {
        margin-bottom: 15px;
        clear: both;
        *zoom: 1
    }

    .layui-form-item:after {
        content: '\20';
        clear: both;
        *zoom: 1;
        display: block;
        height: 0
    }

    .layui-form-label {
        float: left;
        display: block;
        padding: 9px 15px;
        width: 80px;
        font-weight: 400;
        text-align: right
    }

    .layui-form-item .layui-inline {
        margin-bottom: 5px;
        margin-right: 10px
    }

    .layui-input-block, .layui-input-inline {
        position: relative
    }

    .layui-input-block {
        margin-left: 110px;
        min-height: 36px
    }

    .layui-input-inline {
        display: inline-block;
        vertical-align: middle
    }

    .layui-form-item .layui-input-inline {
        float: left;
        width: 190px;
        margin-right: 10px
    }

    .layui-form-text .layui-input-inline {
        width: auto
    }

    .layui-form-mid {
        float: left;
        display: block;
        padding: 8px 0 !important;
        margin-right: 10px
    }

    .layui-form-danger + .layui-form-select .layui-input, .layui-form-danger:focus {
        border-color: #FF5722 !important
    }

    .layui-form-select {
        position: relative
    }

    .layui-form-select .layui-input {
        padding-right: 30px;
        cursor: pointer
    }

    .layui-form-select .layui-edge {
        position: absolute;
        right: 10px;
        top: 50%;
        margin-top: -3px;
        cursor: pointer;
        border-width: 6px;
        border-top-color: #c2c2c2;
        border-top-style: solid;
        transition: all .3s;
        -webkit-transition: all .3s
    }

    .layui-form-select dl {
        display: none;
        position: absolute;
        left: 0;
        top: 42px;
        padding: 5px 0;
        z-index: 999;
        min-width: 100%;
        border: 1px solid #d2d2d2;
        max-height: 300px;
        overflow-y: auto;
        background-color: #fff;
        border-radius: 2px;
        box-shadow: 0 2px 4px rgba(0, 0, 0, .12);
        box-sizing: border-box
    }

    .layui-form-select dl dd, .layui-form-select dl dt {
        padding: 0 10px;
        line-height: 36px;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis
    }

    .layui-form-select dl dt {
        font-size: 12px;
        color: #999
    }

    .layui-form-select dl dd {
        cursor: pointer
    }

    .layui-form-select dl dd:hover {
        background-color: #f2f2f2
    }

    .layui-form-select .layui-select-group dd {
        padding-left: 20px
    }

    .layui-form-select dl dd.layui-select-tips {
        padding-left: 10px !important;
        color: #999
    }

    .layui-form-select dl dd.layui-this {
        background-color: #5FB878;
        color: #fff
    }

    .layui-form-checkbox, .layui-form-select dl dd.layui-disabled {
        background-color: #fff
    }

    .layui-form-selected dl {
        display: block
    }

    .layui-form-checkbox, .layui-form-checkbox *, .layui-form-radio, .layui-form-radio *, .layui-form-switch {
        display: inline-block;
        vertical-align: middle
    }

    .layui-form-selected .layui-edge {
        margin-top: -9px;
        -webkit-transform: rotate(180deg);
        transform: rotate(180deg);
        margin-top: -3px \9
    }

    :root .layui-form-selected .layui-edge {
        margin-top: -9px \0/ IE9
    }

    .layui-form-selectup dl {
        top: auto;
        bottom: 42px
    }

    .layui-select-none {
        margin: 5px 0;
        text-align: center;
        color: #999
    }

    .layui-select-disabled .layui-disabled {
        border-color: #eee !important
    }

    .layui-select-disabled .layui-edge {
        border-top-color: #d2d2d2
    }

    .layui-form-checkbox {
        position: relative;
        height: 30px;
        line-height: 28px;
        margin-right: 10px;
        padding-right: 30px;
        border: 1px solid #d2d2d2;
        cursor: pointer;
        font-size: 0;
        border-radius: 2px;
        -webkit-transition: .1s linear;
        transition: .1s linear;
        box-sizing: border-box
    }

    .layui-form-checkbox:hover {
        border: 1px solid #c2c2c2
    }

    .layui-form-checkbox span {
        padding: 0 10px;
        height: 100%;
        font-size: 14px;
        background-color: #d2d2d2;
        color: #fff;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis
    }

    .layui-form-checkbox:hover span {
        background-color: #c2c2c2
    }

    .layui-form-checkbox i {
        position: absolute;
        right: 0;
        width: 30px;
        color: #fff;
        font-size: 20px;
        text-align: center
    }

    .layui-form-checkbox:hover i {
        color: #c2c2c2
    }

    .layui-form-checked, .layui-form-checked:hover {
        border-color: #5FB878
    }

    .layui-form-checked span, .layui-form-checked:hover span {
        background-color: #5FB878
    }

    .layui-form-checked i, .layui-form-checked:hover i {
        color: #5FB878
    }

    .layui-form-item .layui-form-checkbox {
        margin-top: 4px
    }

    .layui-form-checkbox[lay-skin=primary] {
        height: auto !important;
        line-height: normal !important;
        border: none !important;
        margin-right: 0;
        padding-right: 0;
        background: 0 0
    }

    .layui-form-checkbox[lay-skin=primary] span {
        float: right;
        padding-right: 15px;
        line-height: 18px;
        background: 0 0;
        color: #666
    }

    .layui-form-checkbox[lay-skin=primary] i {
        position: relative;
        top: 0;
        width: 16px;
        height: 16px;
        line-height: 16px;
        border: 1px solid #d2d2d2;
        font-size: 12px;
        border-radius: 2px;
        background-color: #fff;
        -webkit-transition: .1s linear;
        transition: .1s linear
    }

    .layui-form-checkbox[lay-skin=primary]:hover i {
        border-color: #5FB878;
        color: #fff
    }

    .layui-form-checked[lay-skin=primary] i {
        border-color: #5FB878;
        background-color: #5FB878;
        color: #fff
    }

    .layui-checkbox-disbaled[lay-skin=primary] span {
        background: 0 0 !important;
        color: #c2c2c2
    }

    .layui-checkbox-disbaled[lay-skin=primary]:hover i {
        border-color: #d2d2d2
    }

    .layui-form-item .layui-form-checkbox[lay-skin=primary] {
        margin-top: 10px
    }

    .layui-form-switch {
        position: relative;
        height: 22px;
        line-height: 22px;
        width: 42px;
        padding: 0 5px;
        margin-top: 8px;
        border: 1px solid #d2d2d2;
        border-radius: 20px;
        cursor: pointer;
        background-color: #fff;
        -webkit-transition: .1s linear;
        transition: .1s linear
    }

    .layui-form-switch i {
        position: absolute;
        left: 5px;
        top: 3px;
        width: 16px;
        height: 16px;
        border-radius: 20px;
        background-color: #d2d2d2;
        -webkit-transition: .1s linear;
        transition: .1s linear
    }

    .layui-form-switch em {
        position: absolute;
        right: 5px;
        top: 0;
        width: 25px;
        padding: 0 !important;
        text-align: center !important;
        color: #999 !important;
        font-style: normal !important;
        font-size: 12px
    }

    .layui-form-onswitch {
        border-color: #5FB878;
        background-color: #5FB878
    }

    .layui-form-onswitch i {
        left: 32px;
        background-color: #fff
    }

    .layui-form-onswitch em {
        left: 5px;
        right: auto;
        color: #fff !important
    }

    .layui-checkbox-disbaled {
        border-color: #e2e2e2 !important
    }

    .layui-checkbox-disbaled span {
        background-color: #e2e2e2 !important
    }

    .layui-checkbox-disbaled:hover i {
        color: #fff !important
    }

    .layui-form-radio {
        line-height: 28px;
        margin: 6px 10px 0 0;
        padding-right: 10px;
        cursor: pointer;
        font-size: 0
    }

    .layui-form-radio i {
        margin-right: 8px;
        font-size: 22px;
        color: #c2c2c2
    }

    .layui-form-radio span {
        font-size: 14px
    }

    .layui-form-radio i:hover, .layui-form-radioed i {
        color: #5FB878
    }

    .layui-radio-disbaled i {
        color: #e2e2e2 !important
    }

    .layui-form-pane .layui-form-label {
        width: 110px;
        padding: 8px 15px;
        height: 38px;
        line-height: 20px;
        border-width: 1px;
        border-style: solid;
        border-radius: 2px 0 0 2px;
        text-align: center;
        background-color: #FBFBFB;
        overflow: hidden;
        white-space: nowrap;
        text-overflow: ellipsis;
        box-sizing: border-box
    }

    .layui-form-pane .layui-input-inline {
        margin-left: -1px
    }

    .layui-form-pane .layui-input-block {
        margin-left: 110px;
        left: -1px
    }

    .layui-form-pane .layui-input {
        border-radius: 0 2px 2px 0
    }

    .layui-form-pane .layui-form-text .layui-form-label {
        float: none;
        width: 100%;
        border-radius: 2px;
        box-sizing: border-box;
        text-align: left
    }

    .layui-form-pane .layui-form-text .layui-input-inline {
        display: block;
        margin: 0;
        top: -1px;
        clear: both
    }

    .layui-form-pane .layui-form-text .layui-input-block {
        margin: 0;
        left: 0;
        top: -1px
    }

    .layui-form-pane .layui-form-text .layui-textarea {
        min-height: 100px;
        border-radius: 0 0 2px 2px
    }

    .layui-form-pane .layui-form-checkbox {
        margin: 4px 0 4px 10px
    }

    .layui-form-pane .layui-form-radio, .layui-form-pane .layui-form-switch {
        margin-top: 6px;
        margin-left: 10px
    }

    .layui-form-pane .layui-form-item[pane] {
        position: relative;
        border-width: 1px;
        border-style: solid
    }

    .layui-form-pane .layui-form-item[pane] .layui-form-label {
        position: absolute;
        left: 0;
        top: 0;
        height: 100%;
        border-width: 0 1px 0 0
    }

    .layui-form-pane .layui-form-item[pane] .layui-input-inline {
        margin-left: 110px
    }

    @media screen and (max-width: 450px) {
        .layui-form-item .layui-form-label {
            text-overflow: ellipsis;
            overflow: hidden;
            white-space: nowrap
        }

        .layui-form-item .layui-inline {
            display: block;
            margin-right: 0;
            margin-bottom: 20px;
            clear: both
        }

        .layui-form-item .layui-inline:after {
            content: '\20';
            clear: both;
            display: block;
            height: 0
        }

        .layui-form-item .layui-input-inline {
            display: block;
            float: none;
            left: -3px;
            width: auto;
            margin: 0 0 10px 112px
        }

        .layui-form-item .layui-input-inline + .layui-form-mid {
            margin-left: 110px;
            top: -5px;
            padding: 0
        }

        .layui-form-item .layui-form-checkbox {
            margin-right: 5px;
            margin-bottom: 5px
        }
    }

    .layui-layedit {
        border-width: 1px;
        border-style: solid;
        border-radius: 2px
    }

    .layui-layedit-tool {
        padding: 3px 5px;
        border-bottom-width: 1px;
        border-bottom-style: solid;
        font-size: 0
    }

    .layedit-tool-fixed {
        position: fixed;
        top: 0;
        border-top: 1px solid #e2e2e2
    }

    .layui-layedit-tool .layedit-tool-mid, .layui-layedit-tool .layui-icon {
        display: inline-block;
        vertical-align: middle;
        text-align: center;
        font-size: 14px
    }

    .layui-layedit-tool .layui-icon {
        position: relative;
        width: 32px;
        height: 30px;
        line-height: 30px;
        margin: 3px 5px;
        color: #777;
        cursor: pointer;
        border-radius: 2px
    }

    .layui-layedit-tool .layui-icon:hover {
        color: #393D49
    }

    .layui-layedit-tool .layui-icon:active {
        color: #000
    }

    .layui-layedit-tool .layedit-tool-active {
        background-color: #e2e2e2;
        color: #000
    }

    .layui-layedit-tool .layui-disabled, .layui-layedit-tool .layui-disabled:hover {
        color: #d2d2d2;
        cursor: not-allowed
    }

    .layui-layedit-tool .layedit-tool-mid {
        width: 1px;
        height: 18px;
        margin: 0 10px;
        background-color: #d2d2d2
    }

    .layedit-tool-html {
        width: 50px !important;
        font-size: 30px !important
    }

    .layedit-tool-b, .layedit-tool-code, .layedit-tool-help {
        font-size: 16px !important
    }

    .layedit-tool-d, .layedit-tool-face, .layedit-tool-image, .layedit-tool-unlink {
        font-size: 18px !important
    }

    .layedit-tool-image input {
        position: absolute;
        font-size: 0;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        opacity: .01;
        filter: Alpha(opacity=1);
        cursor: pointer
    }

    .layui-layedit-iframe iframe {
        display: block;
        width: 100%
    }

    #LAY_layedit_code {
        overflow: hidden
    }

    .layui-laypage {
        display: inline-block;
        *display: inline;
        *zoom: 1;
        vertical-align: middle;
        margin: 10px 0;
        font-size: 0
    }

    .layui-laypage > a:first-child, .layui-laypage > a:first-child em {
        border-radius: 2px 0 0 2px
    }

    .layui-laypage > a:last-child, .layui-laypage > a:last-child em {
        border-radius: 0 2px 2px 0
    }

    .layui-laypage > :first-child {
        margin-left: 0 !important
    }

    .layui-laypage > :last-child {
        margin-right: 0 !important
    }

    .layui-laypage a, .layui-laypage button, .layui-laypage input, .layui-laypage select, .layui-laypage span {
        border: 1px solid #e2e2e2
    }

    .layui-laypage a, .layui-laypage span {
        display: inline-block;
        *display: inline;
        *zoom: 1;
        vertical-align: middle;
        padding: 0 15px;
        height: 28px;
        line-height: 28px;
        margin: 0 -1px 5px 0;
        background-color: #fff;
        color: #333;
        font-size: 12px
    }

    .layui-laypage a:hover {
        color: #009688
    }

    .layui-laypage em {
        font-style: normal
    }

    .layui-laypage .layui-laypage-spr {
        color: #999;
        font-weight: 700
    }

    .layui-laypage a {
        text-decoration: none
    }

    .layui-laypage .layui-laypage-curr {
        position: relative
    }

    .layui-laypage .layui-laypage-curr em {
        position: relative;
        color: #fff
    }

    .layui-laypage .layui-laypage-curr .layui-laypage-em {
        position: absolute;
        left: -1px;
        top: -1px;
        padding: 1px;
        width: 100%;
        height: 100%;
        background-color: #009688
    }

    .layui-laypage-em {
        border-radius: 2px
    }

    .layui-laypage-next em, .layui-laypage-prev em {
        font-family: Sim sun;
        font-size: 16px
    }

    .layui-laypage .layui-laypage-count, .layui-laypage .layui-laypage-limits, .layui-laypage .layui-laypage-skip {
        margin-left: 10px;
        margin-right: 10px;
        padding: 0;
        border: none
    }

    .layui-laypage .layui-laypage-limits {
        vertical-align: top
    }

    .layui-laypage select {
        height: 22px;
        padding: 3px;
        border-radius: 2px;
        cursor: pointer
    }

    .layui-laypage .layui-laypage-skip {
        height: 30px;
        line-height: 30px;
        color: #999
    }

    .layui-laypage button, .layui-laypage input {
        height: 30px;
        line-height: 30px;
        border-radius: 2px;
        vertical-align: top;
        background-color: #fff;
        box-sizing: border-box
    }

    .layui-laypage input {
        display: inline-block;
        width: 40px;
        margin: 0 10px;
        padding: 0 3px;
        text-align: center
    }

    .layui-laypage input:focus, .layui-laypage select:focus {
        border-color: #009688 !important
    }

    .layui-laypage button {
        margin-left: 10px;
        padding: 0 10px;
        cursor: pointer
    }

    .layui-table, .layui-table-view {
        margin: 10px 0
    }

    .layui-flow-more {
        margin: 10px 0;
        text-align: center;
        color: #999;
        font-size: 14px
    }

    .layui-flow-more a {
        height: 32px;
        line-height: 32px
    }

    .layui-flow-more a * {
        display: inline-block;
        vertical-align: top
    }

    .layui-flow-more a cite {
        padding: 0 20px;
        border-radius: 3px;
        background-color: #eee;
        color: #333;
        font-style: normal
    }

    .layui-flow-more a cite:hover {
        opacity: .8
    }

    .layui-flow-more a i {
        font-size: 30px;
        color: #737383
    }

    .layui-table {
        width: 100%;
        background-color: #fff;
        color: #666
    }

    .layui-table tr {
        transition: all .3s;
        -webkit-transition: all .3s
    }

    .layui-table th {
        text-align: left;
        font-weight: 400
    }

    .layui-table tbody tr:hover, .layui-table thead tr, .layui-table-click, .layui-table-header, .layui-table-hover, .layui-table-mend, .layui-table-patch, .layui-table-tool, .layui-table[lay-even] tr:nth-child(even) {
        background-color: #f2f2f2
    }

    .layui-table td, .layui-table th, .layui-table-fixed-r, .layui-table-header, .layui-table-page, .layui-table-tips-main, .layui-table-tool, .layui-table-view, .layui-table[lay-skin=row], .layui-table[lay-skin=line] {
        border-width: 1px;
        border-style: solid;
        border-color: #e6e6e6
    }

    .layui-table td, .layui-table th {
        position: relative;
        padding: 9px 15px;
        min-height: 20px;
        line-height: 20px;
        font-size: 14px
    }

    .layui-table[lay-skin=line] td, .layui-table[lay-skin=line] th {
        border-width: 0 0 1px
    }

    .layui-table[lay-skin=row] td, .layui-table[lay-skin=row] th {
        border-width: 0 1px 0 0
    }

    .layui-table[lay-skin=nob] td, .layui-table[lay-skin=nob] th {
        border: none
    }

    .layui-table img {
        max-width: 100px
    }

    .layui-table[lay-size=lg] td, .layui-table[lay-size=lg] th {
        padding: 15px 30px
    }

    .layui-table-view .layui-table[lay-size=lg] .layui-table-cell {
        height: 40px;
        line-height: 40px
    }

    .layui-table[lay-size=sm] td, .layui-table[lay-size=sm] th {
        font-size: 12px;
        padding: 5px 10px
    }

    .layui-table-view .layui-table[lay-size=sm] .layui-table-cell {
        height: 20px;
        line-height: 20px
    }

    .layui-table[lay-data] {
        display: none
    }

    .layui-table-box, .layui-table-view {
        position: relative;
        overflow: hidden
    }

    .layui-table-view .layui-table {
        position: relative;
        width: auto;
        margin: 0
    }

    .layui-table-body, .layui-table-header .layui-table, .layui-table-page {
        margin-bottom: -1px
    }

    .layui-table-view .layui-table[lay-skin=line] {
        border-width: 0 1px 0 0
    }

    .layui-table-view .layui-table[lay-skin=row] {
        border-width: 0 0 1px
    }

    .layui-table-view .layui-table td, .layui-table-view .layui-table th {
        padding: 5px 0;
        border-top: none;
        border-left: none
    }

    .layui-table-view .layui-table td {
        cursor: default
    }

    .layui-table-view .layui-form-checkbox[lay-skin=primary] i {
        width: 18px;
        height: 18px
    }

    .layui-table-header {
        border-width: 0 0 1px;
        overflow: hidden
    }

    .layui-table-sort {
        width: 10px;
        height: 20px;
        margin-left: 5px;
        cursor: pointer !important
    }

    .layui-table-sort .layui-edge {
        position: absolute;
        left: 5px;
        border-width: 5px
    }

    .layui-table-sort .layui-table-sort-asc {
        top: 4px;
        border-top: none;
        border-bottom-style: solid;
        border-bottom-color: #b2b2b2
    }

    .layui-table-sort .layui-table-sort-asc:hover {
        border-bottom-color: #666
    }

    .layui-table-sort .layui-table-sort-desc {
        bottom: 4px;
        border-bottom: none;
        border-top-style: solid;
        border-top-color: #b2b2b2
    }

    .layui-table-sort .layui-table-sort-desc:hover {
        border-top-color: #666
    }

    .layui-table-sort[lay-sort=asc] .layui-table-sort-asc {
        border-bottom-color: #000
    }

    .layui-table-sort[lay-sort=desc] .layui-table-sort-desc {
        border-top-color: #000
    }

    .layui-table-cell {
        height: 28px;
        line-height: 28px;
        padding: 0 15px;
        position: relative;
        overflow: hidden;
        text-overflow: ellipsis;
        white-space: nowrap;
        box-sizing: border-box
    }

    .layui-table-cell .layui-form-checkbox[lay-skin=primary] {
        top: -1px;
        vertical-align: middle
    }

    .layui-table-cell .layui-table-link {
        color: #01AAED
    }

    .laytable-cell-checkbox, .laytable-cell-numbers, .laytable-cell-space {
        padding: 0;
        text-align: center
    }

    .layui-table-body {
        position: relative;
        overflow: auto;
        margin-right: -1px
    }

    .layui-table-body .layui-none {
        line-height: 40px;
        text-align: center;
        color: #999
    }

    .layui-table-fixed {
        position: absolute;
        left: 0;
        top: 0
    }

    .layui-table-fixed .layui-table-body {
        overflow: hidden
    }

    .layui-table-fixed-l {
        box-shadow: 0 -1px 8px rgba(0, 0, 0, .08)
    }

    .layui-table-fixed-r {
        left: auto;
        right: -1px;
        border-width: 0 0 0 1px;
        box-shadow: -1px 0 8px rgba(0, 0, 0, .08)
    }

    .layui-table-fixed-r .layui-table-header {
        position: relative;
        overflow: visible
    }

    .layui-table-mend {
        position: absolute;
        right: -49px;
        top: 0;
        height: 100%;
        width: 50px
    }

    .layui-table-tool {
        position: relative;
        width: 100%;
        height: 50px;
        line-height: 30px;
        padding: 10px 15px;
        border-width: 0 0 1px
    }

    .layui-table-page {
        position: relative;
        width: 100%;
        padding: 7px 7px 0;
        border-width: 1px 0 0;
        height: 41px;
        font-size: 12px
    }

    .layui-table-page > div {
        height: 26px
    }

    .layui-table-page .layui-laypage {
        margin: 0
    }

    .layui-table-page .layui-laypage a, .layui-table-page .layui-laypage span {
        height: 26px;
        line-height: 26px;
        margin-bottom: 10px;
        border: none;
        background: 0 0
    }

    .layui-table-page .layui-laypage a, .layui-table-page .layui-laypage span.layui-laypage-curr {
        padding: 0 12px
    }

    .layui-table-page .layui-laypage span {
        margin-left: 0;
        padding: 0
    }

    .layui-table-page .layui-laypage .layui-laypage-prev {
        margin-left: -7px !important
    }

    .layui-table-page .layui-laypage .layui-laypage-curr .layui-laypage-em {
        left: 0;
        top: 0;
        padding: 0
    }

    .layui-table-page .layui-laypage button, .layui-table-page .layui-laypage input {
        height: 26px;
        line-height: 26px
    }

    .layui-table-page .layui-laypage input {
        width: 40px
    }

    .layui-table-page .layui-laypage button {
        padding: 0 10px
    }

    .layui-table-page select {
        height: 18px
    }

    .layui-table-view select[lay-ignore] {
        display: inline-block
    }

    .layui-table-patch .layui-table-cell {
        padding: 0;
        width: 30px
    }

    .layui-table-edit {
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        padding: 0 14px 1px;
        border-radius: 0;
        box-shadow: 1px 1px 20px rgba(0, 0, 0, .15)
    }

    .layui-table-edit:focus {
        border-color: #5FB878 !important
    }

    select.layui-table-edit {
        padding: 0 0 0 10px;
        border-color: #C9C9C9
    }

    .layui-table-view .layui-form-checkbox, .layui-table-view .layui-form-radio, .layui-table-view .layui-form-switch {
        top: 0;
        margin: 0;
        box-sizing: content-box
    }

    .layui-table-view .layui-form-checkbox {
        top: -1px;
        height: 26px;
        line-height: 26px
    }

    body .layui-table-tips .layui-layer-content {
        background: 0 0;
        padding: 0;
        box-shadow: 0 1px 6px rgba(0, 0, 0, .1)
    }

    .layui-table-tips-main {
        margin: -44px 0 0 -1px;
        max-height: 150px;
        padding: 8px 15px;
        font-size: 14px;
        overflow-y: scroll;
        background-color: #fff;
        color: #333
    }

    .layui-code, .layui-upload-list {
        margin: 10px 0
    }

    .layui-table-tips-c {
        position: absolute;
        right: -3px;
        top: -12px;
        width: 18px;
        height: 18px;
        padding: 3px;
        text-align: center;
        font-weight: 700;
        border-radius: 100%;
        font-size: 14px;
        cursor: pointer;
        background-color: #666
    }

    .layui-table-tips-c:hover {
        background-color: #999
    }

    .layui-upload-file {
        display: none !important;
        opacity: .01;
        filter: Alpha(opacity=1)
    }

    .layui-upload-drag, .layui-upload-form, .layui-upload-wrap {
        display: inline-block
    }

    .layui-upload-choose {
        padding: 0 10px;
        color: #999
    }

    .layui-upload-drag {
        position: relative;
        padding: 30px;
        border: 1px dashed #e2e2e2;
        background-color: #fff;
        text-align: center;
        cursor: pointer;
        color: #999
    }

    .layui-upload-drag .layui-icon {
        font-size: 50px;
        color: #009688
    }

    .layui-upload-drag[lay-over] {
        border-color: #009688
    }

    .layui-upload-iframe {
        position: absolute;
        width: 0;
        height: 0;
        border: 0;
        visibility: hidden
    }

    .layui-upload-wrap {
        position: relative;
        vertical-align: middle
    }

    .layui-upload-wrap .layui-upload-file {
        display: block !important;
        position: absolute;
        left: 0;
        top: 0;
        z-index: 10;
        font-size: 100px;
        width: 100%;
        height: 100%;
        opacity: .01;
        filter: Alpha(opacity=1);
        cursor: pointer
    }

    .layui-code {
        position: relative;
        padding: 15px;
        line-height: 20px;
        border: 1px solid #ddd;
        border-left-width: 6px;
        background-color: #F2F2F2;
        color: #333;
        font-family: Courier New;
        font-size: 12px
    }

    .layui-tree {
        line-height: 26px
    }

    .layui-tree li {
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap
    }

    .layui-tree li .layui-tree-spread, .layui-tree li a {
        display: inline-block;
        vertical-align: top;
        height: 26px;
        *display: inline;
        *zoom: 1;
        cursor: pointer
    }

    .layui-tree li a {
        font-size: 0
    }

    .layui-tree li a i {
        font-size: 16px
    }

    .layui-tree li a cite {
        padding: 0 6px;
        font-size: 14px;
        font-style: normal
    }

    .layui-tree li i {
        padding-left: 6px;
        color: #333;
        -moz-user-select: none
    }

    .layui-tree li .layui-tree-check {
        font-size: 13px
    }

    .layui-tree li .layui-tree-check:hover {
        color: #009E94
    }

    .layui-tree li ul {
        display: none;
        margin-left: 20px
    }

    .layui-tree li .layui-tree-enter {
        line-height: 24px;
        border: 1px dotted #000
    }

    .layui-tree-drag {
        display: none;
        position: absolute;
        left: -666px;
        top: -666px;
        background-color: #f2f2f2;
        padding: 5px 10px;
        border: 1px dotted #000;
        white-space: nowrap
    }

    .layui-tree-drag i {
        padding-right: 5px
    }

    .layui-nav {
        position: relative;
        padding: 0 20px;
        background-color: #393D49;
        color: #fff;
        border-radius: 2px;
        font-size: 0;
        box-sizing: border-box
    }

    .layui-nav * {
        font-size: 14px
    }

    .layui-nav .layui-nav-item {
        position: relative;
        display: inline-block;
        *display: inline;
        *zoom: 1;
        vertical-align: middle;
        line-height: 60px
    }

    .layui-nav .layui-nav-item a {
        display: block;
        padding: 0 20px;
        color: #fff;
        color: rgba(255, 255, 255, .7);
        transition: all .3s;
        -webkit-transition: all .3s
    }

    .layui-nav .layui-this:after, .layui-nav-bar, .layui-nav-tree .layui-nav-itemed:after {
        position: absolute;
        left: 0;
        top: 0;
        width: 0;
        height: 5px;
        background-color: #5FB878;
        transition: all .2s;
        -webkit-transition: all .2s
    }

    .layui-nav-bar {
        z-index: 1000
    }

    .layui-nav .layui-nav-item a:hover, .layui-nav .layui-this a {
        color: #fff
    }

    .layui-nav .layui-this:after {
        content: '';
        top: auto;
        bottom: 0;
        width: 100%
    }

    .layui-nav-img {
        width: 30px;
        height: 30px;
        margin-right: 10px;
        border-radius: 50%
    }

    .layui-nav .layui-nav-more {
        content: '';
        width: 0;
        height: 0;
        border-style: solid dashed dashed;
        border-color: #fff transparent transparent;
        overflow: hidden;
        cursor: pointer;
        transition: all .2s;
        -webkit-transition: all .2s;
        position: absolute;
        top: 50%;
        right: 3px;
        margin-top: -3px;
        border-width: 6px;
        border-top-color: rgba(255, 255, 255, .7)
    }

    .layui-nav .layui-nav-mored, .layui-nav-itemed .layui-nav-more {
        margin-top: -9px;
        border-style: dashed dashed solid;
        border-color: transparent transparent #fff
    }

    .layui-nav-child {
        display: none;
        position: absolute;
        left: 0;
        top: 65px;
        min-width: 100%;
        line-height: 36px;
        padding: 5px 0;
        box-shadow: 0 2px 4px rgba(0, 0, 0, .12);
        border: 1px solid #d2d2d2;
        background-color: #fff;
        z-index: 100;
        border-radius: 2px;
        white-space: nowrap
    }

    .layui-nav .layui-nav-child a {
        color: #333
    }

    .layui-nav .layui-nav-child a:hover {
        background-color: #f2f2f2;
        color: #000
    }

    .layui-nav-child dd {
        position: relative
    }

    .layui-nav .layui-nav-child dd.layui-this a, .layui-nav-child dd.layui-this {
        background-color: #5FB878;
        color: #fff
    }

    .layui-nav-child dd.layui-this:after {
        display: none
    }

    .layui-nav-tree {
        width: 200px;
        padding: 0
    }

    .layui-nav-tree .layui-nav-item {
        display: block;
        width: 100%;
        line-height: 45px
    }

    .layui-nav-tree .layui-nav-item a {
        height: 45px;
        line-height: 45px;
        text-overflow: ellipsis;
        overflow: hidden;
        white-space: nowrap
    }

    .layui-nav-tree .layui-nav-item a:hover {
        background-color: #4E5465
    }

    .layui-nav-tree .layui-nav-bar {
        width: 5px;
        height: 0;
        background-color: #009688
    }

    .layui-nav-tree .layui-nav-child dd.layui-this, .layui-nav-tree .layui-nav-child dd.layui-this a, .layui-nav-tree .layui-this, .layui-nav-tree .layui-this > a, .layui-nav-tree .layui-this > a:hover {
        background-color: #009688;
        color: #fff
    }

    .layui-nav-tree .layui-this:after {
        display: none
    }

    .layui-nav-itemed > a, .layui-nav-tree .layui-nav-title a, .layui-nav-tree .layui-nav-title a:hover {
        color: #fff !important
    }

    .layui-nav-tree .layui-nav-child {
        position: relative;
        z-index: 0;
        top: 0;
        border: none;
        box-shadow: none
    }

    .layui-nav-tree .layui-nav-child a {
        height: 40px;
        line-height: 40px;
        color: #fff;
        color: rgba(255, 255, 255, .7)
    }

    .layui-nav-tree .layui-nav-child, .layui-nav-tree .layui-nav-child a:hover {
        background: 0 0;
        color: #fff
    }

    .layui-nav-tree .layui-nav-more {
        top: 20px;
        right: 10px;
        margin: 0
    }

    .layui-nav-itemed .layui-nav-more {
        top: 14px
    }

    .layui-nav-itemed .layui-nav-child {
        display: block;
        padding: 0;
        background-color: rgba(0, 0, 0, .3) !important
    }

    .layui-nav-side {
        position: fixed;
        top: 0;
        bottom: 0;
        left: 0;
        overflow-x: hidden;
        z-index: 999
    }

    .layui-bg-blue .layui-nav-bar, .layui-bg-blue .layui-nav-itemed:after, .layui-bg-blue .layui-this:after {
        background-color: #93D1FF
    }

    .layui-bg-blue .layui-nav-child dd.layui-this {
        background-color: #1E9FFF
    }

    .layui-bg-blue .layui-nav-itemed > a, .layui-nav-tree.layui-bg-blue .layui-nav-title a, .layui-nav-tree.layui-bg-blue .layui-nav-title a:hover {
        background-color: #007DDB !important
    }

    .layui-breadcrumb {
        visibility: hidden;
        font-size: 0
    }

    .layui-breadcrumb > * {
        font-size: 14px
    }

    .layui-breadcrumb a {
        color: #999 !important
    }

    .layui-breadcrumb a:hover {
        color: #5FB878 !important
    }

    .layui-breadcrumb a cite {
        color: #666;
        font-style: normal
    }

    .layui-breadcrumb span[lay-separator] {
        margin: 0 10px;
        color: #999
    }

    .layui-tab {
        margin: 10px 0;
        text-align: left !important
    }

    .layui-tab[overflow] > .layui-tab-title {
        overflow: hidden
    }

    .layui-tab-title {
        position: relative;
        left: 0;
        height: 40px;
        white-space: nowrap;
        font-size: 0;
        border-bottom-width: 1px;
        border-bottom-style: solid;
        transition: all .2s;
        -webkit-transition: all .2s
    }

    .layui-tab-title li {
        display: inline-block;
        *display: inline;
        *zoom: 1;
        vertical-align: middle;
        font-size: 14px;
        transition: all .2s;
        -webkit-transition: all .2s;
        position: relative;
        line-height: 40px;
        min-width: 65px;
        padding: 0 15px;
        text-align: center;
        cursor: pointer
    }

    .layui-tab-title li a {
        display: block
    }

    .layui-tab-title .layui-this {
        color: #000
    }

    .layui-tab-title .layui-this:after {
        position: absolute;
        left: 0;
        top: 0;
        content: '';
        width: 100%;
        height: 41px;
        border-width: 1px;
        border-style: solid;
        border-bottom-color: #fff;
        border-radius: 2px 2px 0 0;
        box-sizing: border-box;
        pointer-events: none
    }

    .layui-tab-bar {
        position: absolute;
        right: 0;
        top: 0;
        z-index: 10;
        width: 30px;
        height: 39px;
        line-height: 39px;
        border-width: 1px;
        border-style: solid;
        border-radius: 2px;
        text-align: center;
        background-color: #fff;
        cursor: pointer
    }

    .layui-tab-bar .layui-icon {
        position: relative;
        display: inline-block;
        top: 3px;
        transition: all .3s;
        -webkit-transition: all .3s
    }

    .layui-tab-item {
        display: none
    }

    .layui-tab-more {
        padding-right: 30px;
        height: auto !important;
        white-space: normal !important
    }

    .layui-tab-more li.layui-this:after {
        border-bottom-color: #e2e2e2;
        border-radius: 2px
    }

    .layui-tab-more .layui-tab-bar .layui-icon {
        top: -2px;
        top: 3px \9;
        -webkit-transform: rotate(180deg);
        transform: rotate(180deg)
    }

    :root .layui-tab-more .layui-tab-bar .layui-icon {
        top: -2px \0/ IE9
    }

    .layui-tab-content {
        padding: 10px
    }

    .layui-tab-title li .layui-tab-close {
        position: relative;
        display: inline-block;
        width: 18px;
        height: 18px;
        line-height: 20px;
        margin-left: 8px;
        top: 1px;
        text-align: center;
        font-size: 14px;
        color: #c2c2c2;
        transition: all .2s;
        -webkit-transition: all .2s
    }

    .layui-tab-title li .layui-tab-close:hover {
        border-radius: 2px;
        background-color: #FF5722;
        color: #fff
    }

    .layui-tab-brief > .layui-tab-title .layui-this {
        color: #009688
    }

    .layui-tab-brief > .layui-tab-more li.layui-this:after, .layui-tab-brief > .layui-tab-title .layui-this:after {
        border: none;
        border-radius: 0;
        border-bottom: 2px solid #5FB878
    }

    .layui-tab-brief[overflow] > .layui-tab-title .layui-this:after {
        top: -1px
    }

    .layui-tab-card {
        border-width: 1px;
        border-style: solid;
        border-radius: 2px;
        box-shadow: 0 2px 5px 0 rgba(0, 0, 0, .1)
    }

    .layui-tab-card > .layui-tab-title {
        background-color: #f2f2f2
    }

    .layui-tab-card > .layui-tab-title li {
        margin-right: -1px;
        margin-left: -1px
    }

    .layui-tab-card > .layui-tab-title .layui-this {
        background-color: #fff
    }

    .layui-tab-card > .layui-tab-title .layui-this:after {
        border-top: none;
        border-width: 1px;
        border-bottom-color: #fff
    }

    .layui-tab-card > .layui-tab-title .layui-tab-bar {
        height: 40px;
        line-height: 40px;
        border-radius: 0;
        border-top: none;
        border-right: none
    }

    .layui-tab-card > .layui-tab-more .layui-this {
        background: 0 0;
        color: #5FB878
    }

    .layui-tab-card > .layui-tab-more .layui-this:after {
        border: none
    }

    .layui-timeline {
        padding-left: 5px
    }

    .layui-timeline-item {
        position: relative;
        padding-bottom: 20px
    }

    .layui-timeline-axis {
        position: absolute;
        left: -5px;
        top: 0;
        z-index: 10;
        width: 20px;
        height: 20px;
        line-height: 20px;
        background-color: #fff;
        color: #5FB878;
        border-radius: 50%;
        text-align: center;
        cursor: pointer
    }

    .layui-timeline-axis:hover {
        color: #FF5722
    }

    .layui-timeline-item:before {
        content: '';
        position: absolute;
        left: 5px;
        top: 0;
        z-index: 0;
        width: 1px;
        height: 100%
    }

    .layui-timeline-item:last-child:before {
        display: none
    }

    .layui-timeline-item:first-child:before {
        display: block
    }

    .layui-timeline-content {
        padding-left: 25px
    }

    .layui-timeline-title {
        position: relative;
        margin-bottom: 10px
    }

    .layui-badge, .layui-badge-dot, .layui-badge-rim {
        position: relative;
        display: inline-block;
        padding: 0 6px;
        font-size: 12px;
        text-align: center;
        background-color: #FF5722;
        color: #fff;
        border-radius: 2px
    }

    .layui-badge {
        height: 18px;
        line-height: 18px
    }

    .layui-badge-dot {
        width: 8px;
        height: 8px;
        padding: 0;
        border-radius: 50%
    }

    .layui-badge-rim {
        height: 18px;
        line-height: 18px;
        border-width: 1px;
        border-style: solid;
        background-color: #fff;
        color: #666
    }

    .layui-btn .layui-badge, .layui-btn .layui-badge-dot {
        margin-left: 5px
    }

    .layui-nav .layui-badge, .layui-nav .layui-badge-dot {
        position: absolute;
        top: 50%;
        margin: -8px 6px 0
    }

    .layui-tab-title .layui-badge, .layui-tab-title .layui-badge-dot {
        left: 5px;
        top: -2px
    }

    .layui-carousel {
        position: relative;
        left: 0;
        top: 0;
        background-color: #f8f8f8
    }

    .layui-carousel > [carousel-item] {
        position: relative;
        width: 100%;
        height: 100%;
        overflow: hidden
    }

    .layui-carousel > [carousel-item]:before {
        position: absolute;
        content: '\e63d';
        left: 50%;
        top: 50%;
        width: 100px;
        line-height: 20px;
        margin: -10px 0 0 -50px;
        text-align: center;
        color: #c2c2c2;
        font-family: layui-icon !important;
        font-size: 30px;
        font-style: normal;
        -webkit-font-smoothing: antialiased;
        -moz-osx-font-smoothing: grayscale
    }

    .layui-carousel > [carousel-item] > * {
        display: none;
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background-color: #f8f8f8;
        transition-duration: .3s;
        -webkit-transition-duration: .3s
    }

    .layui-carousel-updown > * {
        -webkit-transition: .3s ease-in-out up;
        transition: .3s ease-in-out up
    }

    .layui-carousel-arrow {
        display: none \9;
        opacity: 0;
        position: absolute;
        left: 10px;
        top: 50%;
        margin-top: -18px;
        width: 36px;
        height: 36px;
        line-height: 36px;
        text-align: center;
        font-size: 20px;
        border: 0;
        border-radius: 50%;
        background-color: rgba(0, 0, 0, .2);
        color: #fff;
        -webkit-transition-duration: .3s;
        transition-duration: .3s;
        cursor: pointer
    }

    .layui-carousel-arrow[lay-type=add] {
        left: auto !important;
        right: 10px
    }

    .layui-carousel:hover .layui-carousel-arrow[lay-type=add], .layui-carousel[lay-arrow=always] .layui-carousel-arrow[lay-type=add] {
        right: 20px
    }

    .layui-carousel[lay-arrow=always] .layui-carousel-arrow {
        opacity: 1;
        left: 20px
    }

    .layui-carousel[lay-arrow=none] .layui-carousel-arrow {
        display: none
    }

    .layui-carousel-arrow:hover, .layui-carousel-ind ul:hover {
        background-color: rgba(0, 0, 0, .35)
    }

    .layui-carousel:hover .layui-carousel-arrow {
        display: block \9;
        opacity: 1;
        left: 20px
    }

    .layui-carousel-ind {
        position: relative;
        top: -35px;
        width: 100%;
        line-height: 0 !important;
        text-align: center;
        font-size: 0
    }

    .layui-carousel[lay-indicator=outside] {
        margin-bottom: 30px
    }

    .layui-carousel[lay-indicator=outside] .layui-carousel-ind {
        top: 10px
    }

    .layui-carousel[lay-indicator=outside] .layui-carousel-ind ul {
        background-color: rgba(0, 0, 0, .5)
    }

    .layui-carousel[lay-indicator=none] .layui-carousel-ind {
        display: none
    }

    .layui-carousel-ind ul {
        display: inline-block;
        padding: 5px;
        background-color: rgba(0, 0, 0, .2);
        border-radius: 10px;
        -webkit-transition-duration: .3s;
        transition-duration: .3s
    }

    .layui-carousel-ind li {
        display: inline-block;
        width: 10px;
        height: 10px;
        margin: 0 3px;
        font-size: 14px;
        background-color: #e2e2e2;
        background-color: rgba(255, 255, 255, .5);
        border-radius: 50%;
        cursor: pointer;
        -webkit-transition-duration: .3s;
        transition-duration: .3s
    }

    .layui-carousel-ind li:hover {
        background-color: rgba(255, 255, 255, .7)
    }

    .layui-carousel-ind li.layui-this {
        background-color: #fff
    }

    .layui-carousel > [carousel-item] > .layui-carousel-next, .layui-carousel > [carousel-item] > .layui-carousel-prev, .layui-carousel > [carousel-item] > .layui-this {
        display: block
    }

    .layui-carousel > [carousel-item] > .layui-this {
        left: 0
    }

    .layui-carousel > [carousel-item] > .layui-carousel-prev {
        left: -100%
    }

    .layui-carousel > [carousel-item] > .layui-carousel-next {
        left: 100%
    }

    .layui-carousel > [carousel-item] > .layui-carousel-next.layui-carousel-left, .layui-carousel > [carousel-item] > .layui-carousel-prev.layui-carousel-right {
        left: 0
    }

    .layui-carousel > [carousel-item] > .layui-this.layui-carousel-left {
        left: -100%
    }

    .layui-carousel > [carousel-item] > .layui-this.layui-carousel-right {
        left: 100%
    }

    .layui-carousel[lay-anim=updown] .layui-carousel-arrow {
        left: 50% !important;
        top: 20px;
        margin: 0 0 0 -18px
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > *, .layui-carousel[lay-anim=fade] > [carousel-item] > * {
        left: 0 !important
    }

    .layui-carousel[lay-anim=updown] .layui-carousel-arrow[lay-type=add] {
        top: auto !important;
        bottom: 20px
    }

    .layui-carousel[lay-anim=updown] .layui-carousel-ind {
        position: absolute;
        top: 50%;
        right: 20px;
        width: auto;
        height: auto
    }

    .layui-carousel[lay-anim=updown] .layui-carousel-ind ul {
        padding: 3px 5px
    }

    .layui-carousel[lay-anim=updown] .layui-carousel-ind li {
        display: block;
        margin: 6px 0
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-this {
        top: 0
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-carousel-prev {
        top: -100%
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-carousel-next {
        top: 100%
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-carousel-next.layui-carousel-left, .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-carousel-prev.layui-carousel-right {
        top: 0
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-this.layui-carousel-left {
        top: -100%
    }

    .layui-carousel[lay-anim=updown] > [carousel-item] > .layui-this.layui-carousel-right {
        top: 100%
    }

    .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-carousel-next, .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-carousel-prev {
        opacity: 0
    }

    .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-carousel-next.layui-carousel-left, .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-carousel-prev.layui-carousel-right {
        opacity: 1
    }

    .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-this.layui-carousel-left, .layui-carousel[lay-anim=fade] > [carousel-item] > .layui-this.layui-carousel-right {
        opacity: 0
    }

    .layui-fixbar {
        position: fixed;
        right: 15px;
        bottom: 15px;
        z-index: 9999
    }

    .layui-fixbar li {
        width: 50px;
        height: 50px;
        line-height: 50px;
        margin-bottom: 1px;
        text-align: center;
        cursor: pointer;
        font-size: 30px;
        background-color: #9F9F9F;
        color: #fff;
        border-radius: 2px;
        opacity: .95
    }

    .layui-fixbar li:hover {
        opacity: .85
    }

    .layui-fixbar li:active {
        opacity: 1
    }

    .layui-fixbar .layui-fixbar-top {
        display: none;
        font-size: 40px
    }

    body .layui-util-face {
        border: none;
        background: 0 0
    }

    body .layui-util-face .layui-layer-content {
        padding: 0;
        background-color: #fff;
        color: #666;
        box-shadow: none
    }

    .layui-util-face .layui-layer-TipsG {
        display: none
    }

    .layui-util-face ul {
        position: relative;
        width: 372px;
        padding: 10px;
        border: 1px solid #D9D9D9;
        background-color: #fff;
        box-shadow: 0 0 20px rgba(0, 0, 0, .2)
    }

    .layui-util-face ul li {
        cursor: pointer;
        float: left;
        border: 1px solid #e8e8e8;
        height: 22px;
        width: 26px;
        overflow: hidden;
        margin: -1px 0 0 -1px;
        padding: 4px 2px;
        text-align: center
    }

    .layui-util-face ul li:hover {
        position: relative;
        z-index: 2;
        border: 1px solid #eb7350;
        background: #fff9ec
    }

    .layui-anim {
        -webkit-animation-duration: .3s;
        animation-duration: .3s;
        -webkit-animation-fill-mode: both;
        animation-fill-mode: both
    }

    .layui-anim.layui-icon {
        display: inline-block
    }

    .layui-anim-loop {
        -webkit-animation-iteration-count: infinite;
        animation-iteration-count: infinite
    }

    @-webkit-keyframes layui-rotate {
        from {
            -webkit-transform: rotate(0)
        }
        to {
            -webkit-transform: rotate(360deg)
        }
    }

    @keyframes layui-rotate {
        from {
            transform: rotate(0)
        }
        to {
            transform: rotate(360deg)
        }
    }

    .layui-anim-rotate {
        -webkit-animation-name: layui-rotate;
        animation-name: layui-rotate;
        -webkit-animation-duration: 1s;
        animation-duration: 1s;
        -webkit-animation-timing-function: linear;
        animation-timing-function: linear
    }

    @-webkit-keyframes layui-up {
        from {
            -webkit-transform: translate3d(0, 100%, 0);
            opacity: .3
        }
        to {
            -webkit-transform: translate3d(0, 0, 0);
            opacity: 1
        }
    }

    @keyframes layui-up {
        from {
            transform: translate3d(0, 100%, 0);
            opacity: .3
        }
        to {
            transform: translate3d(0, 0, 0);
            opacity: 1
        }
    }

    .layui-anim-up {
        -webkit-animation-name: layui-up;
        animation-name: layui-up
    }

    @-webkit-keyframes layui-upbit {
        from {
            -webkit-transform: translate3d(0, 30px, 0);
            opacity: .3
        }
        to {
            -webkit-transform: translate3d(0, 0, 0);
            opacity: 1
        }
    }

    @keyframes layui-upbit {
        from {
            transform: translate3d(0, 30px, 0);
            opacity: .3
        }
        to {
            transform: translate3d(0, 0, 0);
            opacity: 1
        }
    }

    .layui-anim-upbit {
        -webkit-animation-name: layui-upbit;
        animation-name: layui-upbit
    }

    @-webkit-keyframes layui-scale {
        0% {
            opacity: .3;
            -webkit-transform: scale(.5)
        }
        100% {
            opacity: 1;
            -webkit-transform: scale(1)
        }
    }

    @keyframes layui-scale {
        0% {
            opacity: .3;
            -ms-transform: scale(.5);
            transform: scale(.5)
        }
        100% {
            opacity: 1;
            -ms-transform: scale(1);
            transform: scale(1)
        }
    }

    .layui-anim-scale {
        -webkit-animation-name: layui-scale;
        animation-name: layui-scale
    }

    @-webkit-keyframes layui-scale-spring {
        0% {
            opacity: .5;
            -webkit-transform: scale(.5)
        }
        80% {
            opacity: .8;
            -webkit-transform: scale(1.1)
        }
        100% {
            opacity: 1;
            -webkit-transform: scale(1)
        }
    }

    @keyframes layui-scale-spring {
        0% {
            opacity: .5;
            transform: scale(.5)
        }
        80% {
            opacity: .8;
            transform: scale(1.1)
        }
        100% {
            opacity: 1;
            transform: scale(1)
        }
    }

    .layui-anim-scaleSpring {
        -webkit-animation-name: layui-scale-spring;
        animation-name: layui-scale-spring
    }

    @-webkit-keyframes layui-fadein {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }

    @keyframes layui-fadein {
        0% {
            opacity: 0
        }
        100% {
            opacity: 1
        }
    }

    .layui-anim-fadein {
        -webkit-animation-name: layui-fadein;
        animation-name: layui-fadein
    }

    @-webkit-keyframes layui-fadeout {
        0% {
            opacity: 1
        }
        100% {
            opacity: 0
        }
    }

    @keyframes layui-fadeout {
        0% {
            opacity: 1
        }
        100% {
            opacity: 0
        }
    }

    .layui-anim-fadeout {
        -webkit-animation-name: layui-fadeout;
        animation-name: layui-fadeout
    }
</style>
<style>
    body {
        color: #666;
        background-color: #F2F2F2;
    }

    .fly-panel {
        margin-bottom: 15px;
        border-radius: 2px;
        background-color: #fff;
        box-shadow: 0 1px 2px 0 rgba(0, 0, 0, .05);
    }

    .main {
        margin: 2% auto;
        padding: 50px 50px;
        width: 1080px;
    }

    .right-item-title {
        height: 10px;
        line-height: 10px;
        margin-top: 12px;
        cursor: pointer;
    }

    .right-item li {
        margin-left: 20px;
        margin-top: 3px;
        overflow: hidden;
    }

    .right-item em {
        margin-left: 5px;
        font-style: normal;
        color: #BBBBBB;
    }

    .api-main .title {
        background-color: #F8F8F8;
        height: 40px;
        line-height: 40px;
        padding: 6px;
        padding-left: 20px;
        font-size: 17px;
        font-weight: 480;
        color: #000;
    }

    .tool {
        position: fixed;
        left: 20px;
        top: 20%;
        width: 200px;
        height: 200px;
    }

    ::-webkit-scrollbar {
        display: none; /* Chrome Safari */
    }
</style>
<body>
<!-- <div class="fly-panel tool">233333</div> -->
<div class="fly-panel main">
    <!--<div style="margin-bottom:30px;">
        <p style="float:left;">按下 <code>CTRL + F</code> 可以进行搜索。</p>
        <p style="float:right;">内置Jquery，打开F12可以进行操作。内置request('post','url',data)进行http操作。</p>
    </div>
    <hr style="margin-bottom:20px;clear:both;">-->


    <div class="layui-row layui-col-space20">
        <div class="layui-col-md8">
            {main}
        </div>

        <textarea id="copy" style="display: none"></textarea>
        <div class="layui-col-md4" style="position: fixed; top: 7%; right: 21%; width: 18%; max-height: 90%; overflow-y: scroll">
            {right}
        </div>
    </div>
    <hr style="margin-top:40px;">
    <p style="text-align:center;">
        文档更新时间：{date} </p>
</div>
</body>

<script type="text/javascript">
    $(document).ready(function () {
        $(".clickCopy").click(function () {
            var url = $(this).data('url');
            copyText(url);

            $("html,body").animate({
                  scrollTop: $($(this).find('a').attr("href")).offset().top + "px"
              });
        });
    });

    $('.ctrShowAndHide').click(function () {
        var index = $('.ctrShowAndHide').index(this);
        $('.right-item').eq(index).toggle(300);
    })

    /**
     * 将文本内容复制到剪切板
     * @param str 复制内容
     */
    function copyText(str) {
        $('#copy').text(str).show();
        var ele = document.getElementById("copy");
        ele.select();
        document.execCommand('copy', false, null);
        $('#copy').hide();
    }

    function request(pmethod, purl, pdata = null) {
        $.ajax({
            type: pmethod,
            async: false,
            url: purl,
            data: pdata,
            success: function (x) {
                return x;
            }
        });
    }
</script>
</html>
